PHP7使用新的zend engine3.0将应用程序性能提升近两倍,内存消耗比PHP5.6高出50%,它容许服务更多的并发用户,而不须要额外的硬件,PHP7是考虑到今天的工做负载而设计和重构的php
新功能数组
一、增长标量类型声明,有两个选项安全
强制-强制是默认模式,不须要指定并发
严格-严格的模式已经明确暗示dom
强制模式:<?php 函数
function sum(int ...$ints){性能
return array_sum($ints);设计
}code
print(sum(2,'3',4.1));对象
?>
严格模式:<?php
declare(strict_type = 1);
function sum(int ...$ints){
return array_sum($ints);
}
print(sum(2,'3',4.1));
?>
二、空合并运算符??
<?php
//空合并运算符,它用来替代与isset()函数结合的三元操做。该空若是它存在,而不是空合并运算符返回第一个操做数,不然返回第二个操做数
$user_name = $_GET['username'] ?? 'not passed';
三、飞船运算符
//它用来比较两个表达式,当第一个表达式分别小于等于或者大于第二个表达式时,它返回-1,0,1
print( 1<=>1);
四、常量数组
用define()函数定义数组常量,在PHP5中只能用const关键字来定义她们
五、过滤unserialize
PHP7引入了过滤的unserialize()函数,以便在对不可信数据上的对象进行反序列化提供更好的安全性。它能够防止可能的代码注入,并使开发人员可以对能够反序列化的类进行白名单
六、IntIChar
在PHP7中,增长来一个新的IntlChar类,它试图揭示额外的ICU功能,这个类定义类一些静态方法和常量,能够用来处理unicode字符,在使用这个课程以前,须要安装intl扩展
七、csprng
在PHP7中,引入类两个新的函数来以跨平台的方式生成密码安全的整理和字符串
random_bytes()-生成密码安全的伪随机字节
random_int() -生成密码安全的伪随机整数
八、使用声明
从PHP7开始,能够使用单个use语句从相同的命名空间导入类,函数和常量,而不是使用多个use语句
//befor PHP7
use com\crm\classA;
use com\crm\classB;
//PHP 7
use com\crm\{classA,classB}
九、PHP7引入了一个新的函数intdiv(),它对它的操做数进行整数除法,并将除法运算返回int
十、
从PHP 7开始,错误处理和报告已经改变。而不是经过PHP 5使用的传统错误报告机制来报告错误,如今大多数错误都是经过抛出错误异常来处理的。与异常相似,这些错误异常会一直冒泡,直到它们到达第一个匹配的catch块。若是没有匹配的块,则使用set_exception_handler()安装的默认异常处理程序将被调用。若是没有默认的异常处理程序,那么异常将被转换为致命错误,并将像传统的错误同样处理。
因为错误层次结构不是从Exception扩展的,因此使用catch(Exception $ e){...}块来处理PHP 5中未捕获的异常的代码将不会处理这样的错误。catch(Error $ e){...}块或set_exception_handler()处理程序是处理致命错误所必需的。