PHP 5.6
1、可以使用表达式定义常量
在之前的 PHP 版本中,必须使用静态值来定义常量,声明属性以及指定函数参数默认值。 现在你可以使用包括数值、字符串字面量以及其他常量在内的数值表达式来 定义常量、声明属性以及设置函数参数默认值
f()."\n";echo C::SENTENCE;
可以通过 const 关键字来定义类型为 array 的常量。
2、使用 ...
运算符定义变长参数函数
现在可以不依赖 func_get_args(), 使用 ... 运算符 来实现 变长参数函数
Array( [0] => 1 [1] => 2 [2] => 3)
3、使用 **
进行幂运算
加入右连接运算符 ** 来进行幂运算。 同时还支持简写的 **= 运算符,表示进行幂运算并赋值
4、use function 以及 use const
use 运算符可以在类中导入外部的函数和常量了。 对应的结构为 use function 和 use const
5、加入 hash_equals()
函数,以恒定的时间消耗来进行字符串比较,以避免时序攻击
6、加入 __debugInfo()
当使用 var_dump() 输出对象的时候,可以用来控制要输出的属性和值。返回值必须是个数组。
prop = $val; } public function __debugInfo() { return array( "prop" => $this->prop ); }}var_dump(new C(42));
PHP 5.5
1、新增 Generators
http://php.net/manual/zh/language.generators.overview.php yield关键字用于当函数需要返回一个迭代器的时候,逐个返回值。
这里的xrange是一个迭代,功能和range是一样的,如果使用range函数的话,那么函数内部实现会储存每个迭代的中间过程,即每个中间变 量都有个内存空间,那么首先程序使用的内存空间就大了,而且分配内存,回收内存都会导致程序的运行时间加长。但是如果使用上yield实现的xrange 函数的话,里面所有的中间变量都只使用一个内存$i,这样节省的时间和空间都会变小。
那么为什么yield会有这样的效果呢?联想到lua中的yield,这里就算是协程的概念了。在lua语言中,当程序运行到yield的时候,使 用协程将上下文环境记录住,然后将程序操作权归还到主函数,当主函数调用resume的时候,会重新唤起协程,读取yield记录的上下文。这样形成了程 序语言级别的多协程操作。php 5.5这里的yield也是同样的道理,当程序运行到yield的时候,当前程序就唤起协程记录上下文,然后主函数继续操作,只是php中没有使用如 resume一样的关键字,而是“在使用的时候唤起”协程。比如上例中的foreach迭代器就能唤起yield。所以上面的这个例子就能理解了。
其实照着引用yield来说,好多内部函数,特别是迭代有关的函数应该都有可能进行优化。或许后续会有yield版本和非yield版本的实现同一功能的函数吧
2、新增 finally 关键字
Finally处理流程:和C#,Java等语言一致
3、foreach 支持 list()
foreach 支持通过 list() 将嵌套数组分离到单独的变量。
4、empty() 支持传入一个任意表达式,而不仅是一个变量
5、直接通过下标获取访问数组和字符串字面量的元素或字符
6、新的密码哈希 API
缺点是缺乏互操作性,在需要和其他语言对接时会比较麻烦。
7、新增 boolval() 函数
PHP已经实现了strval、intval和floatval的函数。为了达到一致性将添加boolval函数。
8、新增 array_column() 函数
可用来返回数组中指定的一列。
2135,'name' => 'John'), array('id' => 3245,'name' => 'Smith'), array('id' => 5342,'name' => 'Peter'));//从结果集中取出 name 列$names = array_column($records, 'name');print_r($names);//从结果集中总取出 name 列,用相应的 id 作为键值$names = array_column($records, 'name', 'id');print_r($names);
PHP 5.4
1、新增 Traits
sayHello();
2、新增短数组语法
"value", "key2" => "value2");$arr = array(1,2,3,4);// 简写形式$arr = ["key" => "value", "key2" => "value2"];$arr = [1,2,3,4];
3、新增支持对函数返回数组的成员访问解析
4、无论 php.ini 中是否设置 short_open_tag, 格式总是可用。
这种简写形式被称为 Short Open Tag, 在 PHP5.3 起被默认开启,在 PHP5.4 起总是可用。 使用这种简写形式在 HTML 中嵌入 PHP 变量将会非常方便。
5、内置用于开发的 CLI 模式的 web server
6、新增在实例化时访问类成员
bar();
7、新增了动态访问静态方法的方式
8、闭包支持 $this
9、新增二进制直接量
10、session提供了上传进度支持
通过 $_SESSION["upload_progress_name"]
就可以获得当前文件上传的进度信息,结合 Ajax 就能很容易的实现上传进度条。
11、默认使用 mysqlnd
现在mysql, mysqli, pdo_mysql默认使用mysqlnd本地库,在PHP5.4以前需要:./configure --with-mysqli=mysqlnd
./configure --with-mysqli
12、让 json 更懂中文
13、default_charset从ISO-8859-1已经变为UTF-8
默认发送“Content-Type: text/html; charset=utf-8”
PHP 5.3
1、支持命名空间
/*object(my\name\MyClass)#1 (0) {}object(my\name\MyClass)#2 (0) {}int(1)int(1)*/
2、增加后期静态绑定
在PHP中,我们可以在类中通过self关键字或者CLASS来判断或调用当前类。但有一个问题,如果我们是在子类中调用,得到的结果将是父类。因为在继承父类的时候,静态成员就已经被绑定了。
callFuncXXOO();?>//A::funcXXOO()
PHP 5.3.0中增加了一个static关键字来引用当前类,即实现了延迟静态绑定:
这样就会像预期一样输出了:
B::funcXXOO
3、增加 goto 操作符
goto 语句有可能会导致程序流程不清晰,可读性减弱,但在某些情况下具有其独特的方便之处,例如中断深度嵌套的循环和 if 语句。
//以上运行时会输出 2
4、添加了原生的闭包(Lambda/匿名函数)支持
5、新增两个魔术方法, __callStatic 和 __invoke
用静态方式中调用一个不可访问方法时,__callStatic() 会被调用。
当尝试以调用函数的方式调用一个对象时,__invoke() 方法会被自动调用。//A::__invoke(): Hello World
6、添加 Nowdoc 语法支持
就象 heredoc 结构类似于双引号字符串,Nowdoc 结构是类似于单引号字符串的。Nowdoc 结构很象 heredoc 结构,但是 nowdoc 中不进行解析操作。
7、Heredoc 结构中可以用双引号来声明标识符了。
8、const 关键字可用来在类定义之外定义常量了
和使用 define() 来定义常量不同的是,使用 const 关键字定义常量必须处于最顶端的作用域,因为用此方法是在编译时定义的。即不能在函数内,循环内以及 if 语句之内用 const 来定义常量。
9、三元运算符可以简写省略中间的部分
表达式 expr1 ?: expr3 ,当 expr1 为 TRUE 时返回 expr1,否则返回 expr3。
10、异常可以嵌套了
getMessage()); } }}$foo = new Test;$foo->testing();?>
11、可以动态访问静态变量了
//123
12、mail()函数支持记录发送日志了
在配置文件 php.ini 中可设置日志路径。参数名:mail.log
参考资料
1、
2、 3、 4、 5、 6、