这篇文章主要介绍了PHP7.0版本备注,新版本发布在性能方面大大提升,同时在语言特性方面也改变了不少,以下内容是LCT翻译对官方版本升级备注,需要的朋友可以参考
PHP7.0新版本不仅在性能方面大大提升而且在语言特性方面也改变很多,具体讲解请看下文:
1. 向后不兼容的变化
语言变化
变量处理的变化
间接变量、属性和方法引用现在以从左到右的语义进行解释。一些例子:
$$foo['bar']['baz'] // 解释做 ($$foo)['bar']['baz'] $foo->$bar['baz'] // 解释做 ($foo->$bar)['baz'] $foo->$bar['baz']() // 解释做 ($foo->$bar)['baz']() Foo::$bar['baz']() // 解释做 (Foo::$bar)['baz']()
要恢复以前的行为,需要显式地加大括号:
${$foo['bar']['baz']} $foo->{$bar['baz']} $foo->{$bar['baz']}() Foo::{$bar['baz']}()
全局关键字现在只接受简单变量。像以前的
复制代码 代码如下:
global $$foo->bar;
复制代码 代码如下:
global ${$foo->bar};
function getArray() { return [1, 2, 3]; } $last = array_pop(getArray()); // Strict Standards: 只有变量可以用引用方式传递 $last = array_pop((getArray()));
// Strict Standards: 只有变量可以用引用方式传递
现在无论是否使用括号,都会抛出一个严格标准错误。以前在第二种调用方式下不会有提示。
数组元素或对象属性自动安装引用顺序创建,现在的结果顺序将不同。例如:
$array = []; $array["a"] =& $array["b"]; $array["b"] = 1; var_dump($array); 现在结果是 ["a" => 1, "b" => 1],而以前的结果是 ["b" => 1, "a" => 1]
相关的 RFC:
https://wiki.php.net/rfc/uniform_variable_syntax
https://wiki.php.net/rfc/abstract_syntax_tree
list() 的变化
list() 不再以反序赋值,例如:
复制代码 代码如下:
list($array[], $array[], $array[]) = [1, 2, 3];
var_dump($array);
复制代码 代码如下:
list($a, $b, $c) = [1, 2, 3];
// $a = 1; $b = 2; $c = 3;
不再允许对空的 list() 赋值。如下全是无效的:
list() = $a; list(,,) = $a; list($x, list(), $y) = $a; list() 不再支持对字符串的拆分(以前也只在某些情况下支持)
如下代码:
复制代码 代码如下:
$string = "xy";
list($x, $y) = $string;
此外, list() 现在总是可以处理实现了 ArrayAccess 的对象,例如:
复制代码 代码如下:
list($a, $b) = (object) new ArrayObject([0, 1]);
相关 RFC:
https://wiki.php.net/rfc/fix_list_behavior_inconsistency
foreach 的变化
foreach() 迭代不再影响数组内部指针,数组指针可通过 current()/next() 等系列的函数访问。例如:
复制代码 代码如下:
$array = [0, 1, 2];
foreach ($array as &$val) {
var_dump(current($array));
}
在对数组按值迭代时,foreach 总是在对数组副本进行操作,在迭代中任何对数组的操作都不会影响到迭代行为。例如:
复制代码 代码如下:
$array = [0, 1, 2];
$ref =& $array; // Necessary to trigger the old behavior
foreach ($array as $val) {
var_dump($val);
unset($array[1]);
}
在对数组按引用迭代时,对数组的修改将继续会影响到迭代。不过,现在 PHP 在使用数字作为键时可以更好的维护数组内的位置。例如,在按引用迭代过程中添加数组元素:
复制代码 代码如下:
$array = [0];
foreach ($array as &$val) {
var_dump($val);
$array[1] = 1;
}
对普通(不可遍历的)对象按值或按引用迭代的行为类似于对数组进行按引用迭代。这符合以前的行为,除了如上一点所述的更精确的位置管理的改进。
对可遍历对象的迭代行为保持不变。
相关 RFC: https://wiki.php.net/rfc/php7_foreach
参数处理的变化
不能定义两个同名的函数参数。例如,下面的方法将会触发编译时错误:
复制代码 代码如下:
public function foo($a, $b, $unused, $unused) {
// ...
}
复制代码 代码如下:
public function foo($a, $b, $unused1, $unused2) {
// ...
}
复制代码 代码如下:
function foo($x) {
$x++;
var_dump(func_get_arg(0));
}
复制代码 代码如下:
function foo($x) {
var_dump(func_get_arg(0));
$x++;
}
复制代码 代码如下:
function foo($x) {
$newX = $x + 1;
var_dump(func_get_arg(0));
}
复制代码 代码如下:
function foo($x) {
$x = 42;
throw new Exception;
}
复制代码 代码如下:
Stack trace:
#0 file.php(4): foo(42)
#1 {main}
复制代码 代码如下:
Stack trace:
#0 file.php(4): foo('string')
#1 {main}
同样的限制也会影响到 debug_backtrace() 及其它检查函数参数的函数。
相关 RFC: https://wiki.php.net/phpng
整数处理的变化
无效的八进制表示(包含大于7的数字)现在会产生编译错误。例如,下列代码不再有效:
$i = 0781; // 8 不是一个有效的八进制数字!
以前,无效的数字(以及无效数字后的任何数字)会简单的忽略。以前如上 $i 的值是 7,因为后两位数字会被悄悄丢弃。
二进制以负数镜像位移现在会抛出一个算术错误:
复制代码 代码如下:
var_dump(1 >> -1);
复制代码 代码如下:
var_dump(1
类似的,向右位移的位数超出了整型宽度时,其结果总是 0 或 -1 (依赖于符号):
复制代码 代码如下:
var_dump(1 >> 64); // int(0)
var_dump(-1 >> 64); // int(-1)
字符串处理的变化
包含十六进制数字的字符串不会再被当做数字,也不会被特殊处理。参见例子中的新行为:
复制代码 代码如下: