##PHP 5.4新特性##
掌握
-
traits
trait的引入,可以扩展class的内容,使class在某种形式上实现了多重继承,更加灵活,trait不能被实例化 举个例子,假设有三个类,男人,女人,人,人是男人和女人的父类,双11购物不是人人都有的行为,放在人 这个父类里显然不合适,我们把双11购物单独定义为一个trait,这个双11购物的trait不能自己驱动,需要被 其他类引用,从而让引用trait的类具有购物行为
示例代码:<?php trait Hello { public function sayHello() { echo 'Hello ' . "\n"; } } trait World { public function sayWorld() { echo 'World' . "\n"; } } class MyHelloWorld { use Hello, World; public function sayExclamationMark() { echo '!' . "\n"; } } $o = new MyHelloWorld(); $o->sayHello(); $o->sayWorld(); $o->sayExclamationMark();
需要注意的是,trait的继承顺序
来自当前类的成员覆盖了 trait 的方法,而 trait 则覆盖了被继承的方法当多个trait被同一个类使用的时候,会出现方法冲突的情况,使用关键词insteadof解决
示例代码:<?php trait A { public function smallTalk() { echo 'a'; } public function bigTalk() { echo 'A'; } } trait B { public function smallTalk() { echo 'b'; } public function bigTalk() { echo 'B'; } } class Talker { use A, B { B::smallTalk insteadof A; A::bigTalk insteadof B; } } class Aliased_Talker { use A, B { B::smallTalk insteadof A; A::bigTalk insteadof B; B::bigTalk as talk; } }
-
新增短数组语法
<?php $a = [1, 2, 3, 4]; $a = ['one' => 1, 'two' => 2, 'three' => 3, 'four' => 4];
-
新增支持对函数返回数组的成员访问解析
<?php function foo() { return array(1,3,4,5); } $var =foo()[0];
-
现在不管是否设置 short_open_tag php.ini 选项,<?= 将总是可用
-
新增在实例化时访问类成员
<?php class Test { public function foo() { //todo return 1; } } $var = (new Test)->foo(); >ps:注意括号
-
SESSION 扩展现在能追踪文件的 上传进度 在php.ini中配置session.upload_progress.enabled = On,就会开启文件上传进度跟踪功能
-
max_input_vars 指令
在php.ini文件中,设定max_input_vars的值,可以控制$_GET、$_POST 和 $_COOKIE的最大长度
降低构造哈希碰撞进行拒绝服务攻击的可能性
了解
-
现在闭包支持 $this
-
现在支持 Class::{expr}() 语法 示例代码:
<?php class Utils { public static function test1() { echo 1; } public static function test2() { echo 2; } } $m = 'test'; Utils::{$m . (10-8)}(); Utils::test2();
-
新增二进制直接量,例如:0b001001101
##PHP 5.5新特性##
掌握
-
opcache集成在php发行包
opcache实际上是zend公司的Zend Optimizer Plus,功能类同apc
它的性能优于apc,对opcode进行了优化,关于opcache的更多信息
请移步鸟哥博客 一个关于Zend O+的小分享
因此在安装PHP的时候,编译参数一定要加上--enabled-opcache 推荐配置(php.ini) zend_extension=opcache.so opcache.enable_cli=1 opcache.memory_consumption=128 //共享内存大小, 这个根据你们的需求可调 opcache.interned_strings_buffer=8 //interned string的内存大小, 也可调 opcache.max_accelerated_files=4000 //最大缓存的文件数目 opcache.revalidate_freq=60 //60s检查一次文件更新 opcache.fast_shutdown=1 //打开快速关闭, 打开这个在PHP Request Shutdown的时候,回收内存的速度会提高 opcache.save_comments=0 //不保存文件/函数的注释
-
生成器(Generators)
熟悉python的同学对生成器肯定不会陌生的 其功能是在函数中使用关键词yield,中断函数执行并返回一个能在foreach中使用的迭代器 这个语法应该是PHP5.5中最令人激动的特性了 下面的代码演示了生成器用法,并且做了对比,用来突出生成器的优势<?php ini_set('memory_limit', '512M'); $cmd = isset($argv[1]) ? (int)$argv[1] : 0; function xrange($start, $end, $step = 1) { if($start <= $end) { if($step <= 0) { throw new LogicException('step must be +ve'); } for($i = $start; $i <= $end; $i = $i + $step) { yield $i; } }else{ if($step >= 0) { throw new LogicException('step must be -ve'); } for($i = $start; $i >= $end; $i = $i + $step) { yield $i; } } } if($cmd == 0) { $r = range(1, 1000000); foreach($r as $v) { if($v > 20) { break; } echo "$v\t"; } $m = memory_get_usage(true); echo "\n" . $m/1014/1024 . "M\n"; }else if($cmd == 1){ $r = xrange(1, 1000000); foreach($r as $v) { if($v > 20) { break; } echo "$v\t"; } $m = memory_get_usage(true); echo "\n" . $m / 1014 /1024 . "M\n"; }else{ include 'php-excel.class.php'; $stime = microtime(true); if($cmd == 3) { $data = array(); for($i = 0; $i < 10000;$i++) { $data[] = range(1,100); } $xls = new Excel_XML(); $xls->addWorksheet('test', $data); $xls->writeWorkbook('test.xls', './'); }else{ $data = function($n = 10000){ for($i = 0; $i < $n; $i++) { yield xrange(1,100); } }; $xls = new Excel_XML(); $xls->addWorksheet('test', $data()); $xls->writeWorkbook('test.xls', './'); } $ctime = microtime(true) - $stime; $m = memory_get_usage(true); echo "\n" . $m / 1014 /1024 . "M\n"; echo "cost time:" . $ctime . "s\n"; }
ps:php-excel.class.php文件内容请参考本gist php-excel.php
-
新增 finally 关键字 示例代码:
<?php function getLines($file) { $f = fopen($file, 'r'); try { while ($line = fgets($f)) { yield $line; } } finally { fclose($f); } } foreach(getLines('finally.php') as $v) { echo $v; }
编写代码的时候,一定要养成良好的习惯,及时的释放打开的资源
-
password API
password系列函数,为我们存储密码,实现了更简便安全的方式
密码的存储从明文到md5到md5+salt,到mcrpty+salt password_hash默认使用bcrypt加密算法,自动生成salt,加密密码 示例代码<?php $pw1 = '123456'; $pwdb = password_hash($pw1, PASSWORD_DEFAULT); var_dump($pwdb) . "\n"; var_dump(password_verify($pw1, $pwdb)) . "\n"; $pw2 = '778920'; $pwdb = password_hash($pw2, PASSWORD_DEFAULT); var_dump($pwdb) . "\n"; var_dump(password_verify($pw1, $pwdb)) . "\n";
强烈建议新应用开发密码存储使用内置password系列函数
-
array_column
这个函数早就应该有了
我们从数据库中取出10条记录,想要拿到这十条记录中的指定某一列,之前只能foreach了 现在只需要一个array_coulum函数搞定,这个函数实际意义很大,单独提出来讲了 示例代码:<?php // Array representing a possible record set returned from a database $records = array( array( 'id' => 2135, 'first_name' => 'John', 'last_name' => 'Doe', ), array( 'id' => 3245, 'first_name' => 'Sally', 'last_name' => 'Smith', ), array( 'id' => 5342, 'first_name' => 'Jane', 'last_name' => 'Jones', ), array( 'id' => 5623, 'first_name' => 'Peter', 'last_name' => 'Doe', ) ); $first_names = array_column($records, 'first_name'); print_r($first_names);
熟悉
-
foreach 现在支持 list()
<?php $arr= array( array(1,2,3), array(1,2,3), array(1,2,3), ); foreach($arr as list($a, $b, $c)) { //todo } >ps:需要注意的是,遍历数组的子数组个数要一样
-
empty() 支持任意表达式,函数调用也可以使用empty了
了解
- 改进 GD
翻转支持使用新的 imageflip() 函数
高级裁剪支持使用 imagecrop() & imagecropauto() 函数
WebP 的读写分别支持使用 imagecreatefromwebp() & imagewebp()
另外PHP5.4和PHP5.5新增的function,新增的class,新增的interface,新增的全局常量还是挺多的
想了解的,可以查看下面链接
http://www.php.net/manual/zh/migration55.new-functions.php
http://www.php.net/manual/zh/migration55.classes.php
http://www.php.net/manual/zh/migration55.new-methods.php
http://www.php.net/manual/zh/migration55.global-constants.php
http://www.php.net/manual/zh/migration54.functions.php
http://www.php.net/manual/zh/migration54.classes.php
http://www.php.net/manual/zh/migration54.methods.php
http://www.php.net/manual/zh/migration54.global-constants.php