也许你已经知道,重头戏 PHP 7 的发布将在今年到来!如今,让咱们来了解一下,新版本有哪些新功能与改进。html
在本系列的 第一篇 ,咱们介绍了 PHP 7 中最重要的一些不兼容性修复以及两大新特性。在本文中,咱们将了解 PHP 7 的另外六大功能。git
新增长的转义字符—— \u,容许咱们在 PHP 字符串内明确指定 Unicode 字符代码点(以十六进制):github
此处使用的语法为 \u{CODEPOINT} 。例如这个绿色的心形,?, 能够表示为 PHP 字符串 __"\u{1F49A}"__。express
另外一个新的操做符—— Null 合并操做符 ?? ,实际上是传说中的三目运算符 。若是它不是 Null ,将返回左操做数,不然返回右操做数。数组
重点在于,若是左操做数是一个不存在的变量,也不会引发注意。这就像 isset() ,而不像 ?: 短三目运算符。服务器
你还能够连接该操做符,从而返回给定集合的第一个非 null 值。php7
$config = $config ?? $this->config ?? static::$defaultConfig;
以前,在 PHP 5.4 添加的 Closure->bindTo() 与 Closure::bind() 容许你改变 $this 和调用范围的绑定,同时或单独地,建立一个重复闭包。闭包
如今,PHP 7 增长了在调用时达到上述功能的简便方法,经过 Closure->call() 将 $this 和调用范围绑定至同一对象 。该方法将对象做为首个参数,而后是传到闭包中的其余参数,以下:函数
class HelloWorld { private $greeting = "Hello"; } $closure = function($whom) { echo $this->greeting . ' ' . $whom; } $obj = new HelloWorld(); $closure->call($obj, 'World'); // Hello World
若是你曾经从同一命名空间导入多个类,而你的 IDE 能自动完成,你确定会很高兴。对于其余人,为了简便起见,PHP 7 如今有了 组使用声明。这让你快速清楚地指定屡次类似的 导入:
// Original use Framework\Component\SubComponent\ClassA; use Framework\Component\SubComponent\ClassB as ClassC; use Framework\Component\OtherComponent\ClassD; // With Group Use use Framework\Component\{ SubComponent\ClassA, SubComponent\ClassB as ClassC, OtherComponent\ClassD };
你也能够在常量导入与函数导入时与 use function、use const 一块儿使用它。同时也支持混合导入。
use Framework\Component\{ SubComponent\ClassA, function OtherComponent\someFunction, const OtherComponent\SOME_CONSTANT };
生成器有两大新功能。首先是 生成器返回表达式,它容许你在生成器(成功)完成时返回一个值。
PHP 7 以前,若是你尝试返回任何值将致使错误。然而,如今你能够调用 $generator->getReturn() 来获取返回值。
若是生成器还没有返回,或抛出未捕获的异常,调用 $generator->getReturn() 将抛出一个异常。
若是生成器已完成,但没有返回,则返回空。
举例以下:
function gen() { yield "Hello"; yield " "; yield "World!"; return "Goodbye Moon!"; } $gen = gen(); foreach ($gen as $value) { echo $value; } // Outputs "Hello" on iteration 1, " " on iterator 2, and "World!" on iteration 3 echo $gen->getReturn(); // Goodbye Moon!
第二个功能则更使人兴奋:生成器委托。这容许你返回另外一个可迭代结构,它能够迭代自身——不管是数组,迭代器,仍是另外一个生成器。
重要的是,子结构的迭代是由最外层的原始循环完成的,如同单一的平面结构,而非递归结构。
当向生成器发送数据或异常时也同理。这些数据或异常会直接传到子结构中,就像被调用直接控制。
这是使用了 <expression>
语法的 yield
,像这样:
function hello() { yield "Hello"; yield " "; yield "World!"; yield from goodbye(); } function goodbye() { yield "Goodbye"; yield " "; yield "Moon!"; } $gen = hello(); foreach ($gen as $value) { echo $value; }
在每次迭代中,将输出:
"Hello"
" "
"World!"
"Goodbye"
" "
"Moon!"
值得一提的一点警告是,因为子结构能够产生本身的键,屡次迭代彻底可能返回相同的键——若是这对你很重要,你须要本身想办法避免。
在 PHP 中,致命和可捕获的致命错误一直没法处理,或者很难处理 。但有了内部异常 之后,许多这类错误如今均可以抛出异常了。
如今,当一个致命或可捕获的致命错误发生时,会抛出一个异常,容许你从容地处理它。若是你不进行处理,它将成为未捕获的异常这类传统的致命错误。
这些异常是 \EngineException 对象。它们不像全部的用户异常,并不继承自 \Exception 类。这是为了确保如今捕获 \Exception 类的代码从此不会开始捕获致命错误。从而保持向后兼容性。
在未来,若是你想同时捕获传统异常和内部异常,你须要捕获他们新的共享父类,\BaseException。
此外, eval()’ed 代码中的解析错误会抛出 \ParseException,而类型不匹配将抛出一个 \TypeException。
以下例:
try { nonExistentFunction(); } catch (\EngineException $e) { var_dump($e); } object(EngineException)#1 (7) { ["message":protected]=> string(32) "Call to undefined function nonExistantFunction()" ["string":"BaseException":private]=> string(0) "" ["code":protected]=> int(1) ["file":protected]=> string(17) "engine-exceptions.php" ["line":protected]=> int(1) ["trace":"BaseException":private]=> array(0) { } ["previous":"BaseException":private]=> NULL }
OneAPM for PHP 可以深刻到全部 PHP 应用内部完成应用性能管理 可以深刻到全部 PHP 应用内部完成应用性能管理和监控,包括代码级别性能问题的可见性、性能瓶颈的快速识别与追溯、真实用户体验监控、服务器监控和端到端的应用性能管理。
距离 PHP 7.0.0 发布只有八个月了(译者翻译时所剩时日很少),该版本极可能是 PHP 历史上性能最快的一版。虽然如今它只具有内部测试品质(目前 RC5 已能够下载) ,但 PHP 7 的确让人期待。
而且,你能帮助它变得更好。
使用 Rasmus’s 的 PHP 7 vagrant 沙盒,开始运行你的测试套件,或执行常规的质量检验。向项目报告错误,并按期重试。
使用 PHP 7 的一大障碍是确保更新全部扩展使之与新的 Zend Engine 3 兼容。
若是你使用的扩展较为小众,没有获得其维护者足够的关注——或者你使用本身的扩展——请查看 GoPHP7-ext 项目从而确保 PHP 7 发布后一切都准备稳当。
PHP 7 中的每一个新功能都有一个 RFC 。你能够在 PHP.net 维基 找到他们,并在此基础上写新文档。你能够在 在线GUI 环境下 写,包括提交(若是你有 karma)或提交补丁以供审核。
PHP 7 将是伟大的!
PHP是全世界最好的语言,没有之一 :)
抓紧测试你的应用程序。帮助迁移扩展。
P.S. 你已经在使用 PHP 7 了么?你对新功能有何感觉?是否有你不满意,或者不喜欢的地方?你认为你会什么时候升级?让咱们知道你的想法!
分享你的想法,尽在 APM俱乐部!
OneAPM for PHP 可以深刻到全部 PHP 应用内部完成应用性能管理 可以深刻到全部 PHP 应用内部完成应用性能管理和监控,包括代码级别性能问题的可见性、性能瓶颈的快速识别与追溯、真实用户体验监控、服务器监控和端到端的应用性能管理。