Home  >  Article  >  php教程  >  php5.3 PHP5.4 PHP5.5 php5.6 新特性/使用PHP5.5/PHP5.6要注意的

php5.3 PHP5.4 PHP5.5 php5.6 新特性/使用PHP5.5/PHP5.6要注意的

WBOY
WBOYOriginal
2016-06-06 19:59:181339browse

因为用到PHP新版本,一些新特性必须要了解,且有些可以在开发时就使用,如果不使用,那么何必升级PHP版本呢,显得有些得不偿失了! 所以整理了一下 一些特性,有可能不全,待添加 1.PHP 5.3中的新特性 1.1 PHP 5.3中的新特性 1.1.1. 支持命名空间 (Namespace

因为用到PHP新版本,一些新特性必须要了解,且有些可以在开发时就使用,如果不使用,那么何必升级PHP版本呢,显得有些得不偿失了!
所以整理了一下 一些特性,有可能不全,待添加

1.PHP 5.3中的新特性 

1.1 PHP 5.3中的新特性 

1.1.1. 支持命名空间 (Namespace)

毫无疑问,命名空间是PHP5.3所带来的最重要的新特性。
在PHP5.3中,则只需要指定不同的命名空间即可,命名空间的分隔符为反斜杆\。 
select.php 
<?php namespace Zend\Db\Table;  
class Select {}  
这样即使其它命名空间下存在名为Select的类,程序在调用时也不会产生冲突。代码的可读性也有所增加。 
调用方法 
call.php
<?php //namespace Zend\Db;  
include(&#39;select.php&#39;);  
$s = new Zend\Db\Table\Select();  
$s->test();  

1.1.2. 支持延迟静态绑定(Late Static Binding)

在PHP5中,我们可以在类中通过self关键字或者__CLASS__来判断或调用当前类。但有一个问题,如果我们是在子类中调用,得到的结果将是父类。因为在继承父类的时候,静态成员就已经被绑定了。 例如: 

<?php class A {  
    public static function who() {  
        echo __CLASS__;  
    }  
    public static function test() {  
        self::who();  
    }  
}  
class B extends A {  
    public static function who() {  
         echo __CLASS__;  
    }  
}  
B::test();  
以上代码输出的结果是: 

这和我们的预期不同,我们原来想得到子类的相应结果。 
PHP 5.3.0中增加了一个static关键字来引用当前类,即实现了延迟静态绑定: 
<?php class A {  
    public static function who() {  
        echo __CLASS__;  
    }  
    public static function test() {  
        static::who(); // 这里实现了延迟的静态绑定  
    }  
}  
class B extends A {  
    public static function who() {  
         echo __CLASS__;  
    }  
}  
  
B::test();  
以上代码输出的结果是: 

1.1.3. 支持goto语句

多数计算机程序设计语言中都支持无条件转向语句goto,当程序执行到goto语句时,即转向由goto语句中的标号指出的程序位置继续执行。尽管goto语句有可能会导致程序流程不清晰,可读性减弱,但在某些情况下具有其独特的方便之处,例如中断深度嵌套的循环和 if 语句。 
<?php goto a;  
echo &#39;Foo&#39;;  
a:  
echo &#39;Bar&#39;;  
for($i=0,$j=50; $i<100; $i++) {  
  while($j--) {  
    if($j==17) goto end;  
  }   
}  
echo "i = $i";  
end:  
echo &#39;j hit 17&#39;;

1.1.4. 支持闭包、Lambda/Anonymous函数

闭包(Closure)函数和Lambda函数的概念来自于函数编程领域。例如JavaScript 是支持闭包和 lambda 函数的最常见语言之一。 
在PHP中,我们也可以通过create_function()在代码运行时创建函数。但有一个问题:创建的函数仅在运行时才被编译,而不与其它代码同时被编译成执行码,因此我们无法使用类似APC这样的执行码缓存来提高代码执行效率。
在PHP5.3中,我们可以使用Lambda/匿名函数来定义一些临时使用(即用即弃型)的函数,以作为array_map()/array_walk()等函数的回调函数。 
<?php echo preg_replace_callback(&#39;~-([a-z])~&#39;, function ($match) {  
    return strtoupper($match[1]);  
}, &#39;hello-world&#39;);  
// 输出 helloWorld  
$greet = function($name)  
{  
    printf("Hello %s\r\n", $name);  
};  
$greet(&#39;World&#39;);  
$greet(&#39;PHP&#39;);  
//...在某个类中  
$callback =      function ($quantity, $product) use ($tax, &$total)         {  
   $pricePerItem = constant(__CLASS__ . "::PRICE_" .  strtoupper($product));  
   $total += ($pricePerItem * $quantity) * ($tax + 1.0);  
 };  
array_walk($products, $callback);

1.1.5. 新增两个魔术方法__callStatic()和__invoke() 

PHP中原本有一个魔术方法__call(),当代码调用对象的某个不存在的方法时该魔术方法会被自动调用。新增的__callStatic()方法则只用于静态类方法。当尝试调用类中不存在的静态方法时,__callStatic()魔术方法将被自动调用。 
<?php class MethodTest {  
    public function __call($name, $arguments) {  
        // 参数 $name 大小写敏感  
        echo "调用对象方法 &#39;$name&#39; "  
             . implode(&#39; -- &#39;, $arguments). "\n";  
    }  
    /**  PHP 5.3.0 以上版本中本类方法有效  */  
    public static function __callStatic($name, $arguments) {  
        // 参数 $name 大小写敏感  
        echo "调用静态方法 &#39;$name&#39; "  
             . implode(&#39; -- &#39;, $arguments). "\n";  
    }  
}  

$obj = new MethodTest;  
$obj->runTest('通过对象调用');  
MethodTest::runTest('静态调用');  // As of PHP 5.3.0  
以上代码执行后输出如下: 
调用对象方法'runTest' –- 通过对象调用调用静态方法'runTest' –- 静态调用 
以函数形式来调用对象时,__invoke()方法将被自动调用。 
<?php class MethodTest {  
    public function __call($name, $arguments) {  
        // 参数 $name 大小写敏感  
        echo "Calling object method &#39;$name&#39; "  
             . implode(&#39;, &#39;, $arguments). "\n";  
    }  
  
    /**  PHP 5.3.0 以上版本中本类方法有效  */  
    public static function __callStatic($name, $arguments) {  
        // 参数 $name 大小写敏感  
        echo "Calling static method &#39;$name&#39; "  
             . implode(&#39;, &#39;, $arguments). "\n";  
    }  
}  
$obj = new MethodTest;  
$obj->runTest('in object context');  
MethodTest::runTest('in static context');  // As of PHP 5.3.0

1.1.6. 新增Nowdoc语法

用法和Heredoc类似,但使用单引号。Heredoc则需要通过使用双引号来声明。 
Nowdoc中不会做任何变量解析,非常适合于传递一段PHP代码。 
<?php // Nowdoc 单引号 PHP 5.3之后支持  
$name = &#39;MyName&#39;;  
echo <<<&#39;EOT&#39;  
My name is "$name".  
EOT;  
//上面代码输出 My name is "$name". ((其中变量不被解析)  
// Heredoc不加引号  
echo <<<FOOBAR  
Hello World!  
FOOBAR;  
//或者 双引号 PHP 5.3之后支持  
echo <<<"FOOBAR"  
Hello World!  
FOOBAR;
支持通过Heredoc来初始化静态变量、类成员和类常量。 
<?php // 静态变量  
function foo()  
{  
    static $bar = <<<LABEL  
Nothing in here...  
LABEL;  
}  
// 类成员、常量  
class foo  
{  
    const BAR = <<<FOOBAR  
Constant example  
FOOBAR;  
  
    public $baz = <<<FOOBAR  
Property example  
FOOBAR;  
}

1.1.7. 在类外也可使用const来定义常量

//PHP中定义常量通常是用这种方式
define("CONSTANT", "Hello world.");

//并且新增了一种常量定义方式
const CONSTANT = 'Hello World';

1.1.8. 三元运算符增加了一个快捷书写方式

原本格式为是(expr1) ? (expr2) : (expr3) 
如果expr1结果为True,则返回expr2的结果。

PHP5.3新增一种书写方式,可以省略中间部分,书写为expr1 ?: expr3 
如果expr1结果为True,则返回expr1的结果 
//原格式
$expr=$expr1?$expr1:$expr2
//新格式
$expr=$expr1?:$expr2

1.1.9. HTTP状态码在200-399范围内均被认为访问成功 

1.1.10.支持动态调用静态方法 

class Test{  
    public static function testgo()  
    {  
         echo "gogo!";  
    }  
}  
$class = 'Test';  
$action = 'testgo';  
$class::$action();  //输出 "gogo!" 

1.2.PHP5.3中其它值得注意的改变 

1.1.1. 修复了大量bug 
1.1.2. PHP性能提高 
1.1.3. php.ini中可使用变量 
1.1.4. mysqlnd进入核心扩展 理论上说该扩展访问mysql速度会较之前的MySQL 和 MySQLi 扩展快(参见http://dev.mysql.com/downloads/connector/php-mysqlnd/) 
1.1.5. ext/phar、ext/intl、ext/fileinfo、ext/sqlite3和ext/enchant等扩展默认随PHP绑定发布。其中Phar可用于打包PHP程序,类似于Java中的jar机制。 

1.1.6. ereg 正则表达式函数 不再默认可用,请使用速度更快的PCRE 正则表达式函数

详细的请看 http://blog.csdn.net/baiwz/article/details/9077825

1.3 弃用功能

PHP 5.3.0 新增了两个错误等级: E_DEPRECATED 和 E_USER_DEPRECATED. 错误等级 E_DEPRECATED 被用来说明一个函数或者功能已经被弃用. E_USER_DEPRECATED 等级目的在于表明用户代码中的弃用功能, 类似于 E_USER_ERROR 和 E_USER_WARNING 等级.

下面是被弃用的 INI 指令列表. 使用下面任何指令都将导致 E_DEPRECATED 错误.
define_syslog_variables
register_globals
register_long_arrays
safe_mode
magic_quotes_gpc
magic_quotes_runtime
magic_quotes_sybase
弃用 INI 文件中以 '#' 开头的注释.
弃用函数:
call_user_method() (使用 call_user_func() 替代)
call_user_method_array() (使用 call_user_func_array() 替代)
define_syslog_variables()
dl()
ereg() (使用 preg_match() 替代)
ereg_replace() (使用 preg_replace() 替代)
eregi() (使用 preg_match() 配合 'i' 修正符替代)
eregi_replace() (使用 preg_replace() 配合 'i' 修正符替代)
set_magic_quotes_runtime() 以及它的别名函数 magic_quotes_runtime()
session_register() (使用 $_SESSION 超全部变量替代)
session_unregister() (使用 $_SESSION 超全部变量替代)
session_is_registered() (使用 $_SESSION 超全部变量替代)
set_socket_blocking() (使用 stream_set_blocking() 替代)
split() (使用 preg_split() 替代)
spliti() (使用 preg_split() 配合 'i' 修正符替代)
sql_regcase()
mysql_db_query() (使用 mysql_select_db() 和 mysql_query() 替代)
mysql_escape_string() (使用 mysql_real_escape_string() 替代)
废弃以字符串传递区域设置名称. 使用 LC_* 系列常量替代.
mktime() 的 is_dst 参数. 使用新的时区处理函数替代.
弃用的功能:
弃用通过引用分配 new 的返回值.
调用时传递引用被弃用.

2.PHP 5.4中的新特性

2.1.PHP 5.4中的新特性

2.1.1. Buid-in web server内置了一个简单的Web服务器

把当前目录作为Root Document只需要这条命令即可:
$ php -S localhost:3300
也可以指定其它路径:
$ php -S localhost:3300 -t /path/to/root
还可以指定路由:
$ php -S localhost:3300 router.php

2.1.2.Traits

Traits提供了一种灵活的代码重用机制,即不像interface一样只能定义方法但不能实现,又不能像class一样只能单继承。至于在实践中怎样使用,还需要深入思考。
魔术常量为__TRAIT__
官网的一个例子:
trait SayWorld {
        public function sayHello() {
                parent::sayHello();
                echo "World!\n";
                echo 'ID:' . $this->id . "\n";
        }
}

class Base {
        public function sayHello() {
                echo 'Hello ';
        }
}

class MyHelloWorld extends Base {
        private $id;

        public function __construct() {
                $this->id = 123456;
        }

        use SayWorld;
}

$o = new MyHelloWorld();
$o->sayHello();

/*will output:
Hello World!
ID:123456
 */

2.1.3. Short array syntax 数组简短语法

$arr = [1,'james', 'james@fwso.cn'];
$array = [
  "foo" => "bar",
  "bar" => "foo"
  ];

2.1.4. Array dereferencing 数组值

function myfunc() {
    return array(1,'james', 'james@fwso.cn');
}
我认为比数组简短语法更方便的是dereferencing,以前我们需要这样:
$arr = myfunc();
echo $arr[1];
在PHP5.4中这样就行了:
echo myfunc()[1];
其他:
$name = explode(",", "Laruence,male")[0];
explode(",", "Laruence,male")[3] = "phper";
本例要注意一个要点 http://www.laruence.com/2011/12/19/2409.html

2.1.5. Upload progress 文件上传

Session提供了上传进度支持,通过$_SESSION["upload_progress_name"]就可以获得当前文件上传的进度信息,结合Ajax就能很容易实现上传进度条了。
详细的看http://www.laruence.com/2011/10/10/2217.html

2.1.6. JsonSerializable Interface  [JSON 序列化对象]

实现了JsonSerializable接口的类的实例在json_encode序列化的之前会调用jsonSerialize方法,而不是直接序列化对象的属性。
参考http://www.laruence.com/2011/10/10/2204.html

2.1.7. Use mysqlnd by default

现在mysql, mysqli, pdo_mysql默认使用mysqlnd本地库,在PHP5.4以前需要:
$./configure --with-mysqli=mysqlnd
现在:
$./configure --with-mysqli

以上来自:http://www.hdj.me/php54

2.1.8.实例化类

class test{
    function show(){
return 'test';
    }
}
echo (new test())->show();

2.1.9.支持 Class::{expr}() 语法

foreach ([new Human("Gonzalo"), new Human("Peter")] as $human) {
    echo $human->{'hello'}();
}

2.1.10.Callable typehint
function foo(callable $callback) {
}
  则:
  foo("false"); //错误,因为false不是callable类型
  foo("printf"); //正确
  foo(function(){}); //正确
class A {
  static function show() {
    }
}
  foo(array("A", "show")); //正确

2.1.11.函数类型提示的增强

由于php是弱类型的语言,因此在php 5.0后,引入了函数类型提示的功能,其含义为对于传入函数中的参数都进行类型检查,举个例子,有如下的类:
class bar {
function foo(bar $foo) {
}
//其中函数foo中的参数规定了传入的参数必须为bar类的实例,否则系统会判断出错。同样对于数组来说,也可以进行判断,比如:
function foo(array $foo) {
}
}
  foo(array(1, 2, 3)); // 正确,因为传入的是数组
  foo(123); // 不正确,传入的不是数组

2.1.12.新增加了$_SERVER["REQUEST_TIME_FLOAT"]

这个是用来统计服务请求时间的,并用ms来表示

echo "脚本执行时间 ", round(microtime(true) - $_SERVER["REQUEST_TIME_FLOAT"], 2), "s";

2.1.13. 让Json更懂中文(JSON_UNESCAPED_UNICODE)

echo json_encode("中文", JSON_UNESCAPED_UNICODE);
//"中文"

2.1.14. 二进制直接量(binary number format)

$bin  = 0b1101;
echo $bin;
//13

2.2 PHP 5.4.0 性能大幅提升, 修复超过100个bug. 

废除了register_globals, magic_quotes以及安全模式。 
另外值得一提的是多字节支持已经默认启用了,
default_charset从ISO-8859-1已经变为UTF-8. 
默认发送“Content-Type: text/html; charset=utf-8”,
你再也不需要在HTML里写meta tag,也无需为UTF-8兼容而传送额外的header了。

删除的特性
最后,我们集中整理了几年来标记为已弃用的多个特性。这些特性包括 allow_call_time_pass_reference、define_syslog_variables、highlight.bg、register_globals、register_long_arrays、magic_quotes、safe_mode、zend.ze1_compatibility_mode、session.bug_compat42、session.bug_compat_warn 以及 y2k_compliance。
除了这些特性之外,magic_quotes 可能是最大的危险。在早期版本中,未考虑因 magic_quotes 出错导致的后果,简单编写且未采取任何举措使自身免受 SQL 注入攻击的应用程序都通过 magic_quotes 来保护。如果在升级到 PHP 5.4 时未验证已采取正确的 SQLi 保护措施,则可能导致安全漏洞。

其他改动和特性
有一种新的“可调用的”类型提示,用于某方法采用回调作为参数的情况。
htmlspecialchars() 和 htmlentities() 现在可更好地支持亚洲字符,如果未在 php.ini 文件中显式设置 PHP default_charset,这两个函数默认使用 UTF-8 而不是 ISO-8859-1。
=(精简回显语法)现在始终可用,无论 short_tags ini 设置的值为何。这应该使模板化系统创建者感到满意。
会话 ID 现在默认通过 /dev/urandom(或等效文件)中的熵生成,而不是与早期版本一样成为必须显式启用的一个选项。
mysqlnd 这一捆绑的 MySQL 原生驱动程序库现在默认用于与 MySQL 通信的各种扩展,除非在编译时通过 ./configure 被显式覆盖。

可能还有 100 个小的改动和特性。从 PHP 5.3 升级到 5.4 应该极为顺畅,但请阅读迁移指南加以确保。如果您从早期版本升级,执行的操作可能稍多一些。请查看以前的迁移指南再开始升级。

2.3.PHP5.4弃用功能

备受指责的 Register Globals 已从 PHP 中完全删除。十年来,该特性一直以其频繁发生的安全漏洞而著称。2002年该特性被设置为默认关闭。2009年发布的 PHP5.3 将该特性标记为“弃用”,想必从那时起,大部分开发人员已经不再使用它。
从 PHP 中移除的另一个不讨喜的特性是 Magic Quotes。Magic Quotes 本意是对字符串进行自动转义(escape)以试图避免 SQL 注入攻击。但是由于字符串的转义使用方法常与特定背景相关,因此,比起试图解决的问题,它反而造成了更多的问题。该特性同 Register Globals 一样,也在 2009 年被标记为“弃用”。
PHP 中的 break 和 continue 语句之后可以跟上一个参数用来指明跳出的循环层数。如果不指定参数,它会像 VB、C#或 Java 一样跳出最内层的循环。在 PHP 5.4 之前,开发人员可以向 break 语句传递一个变量,而现在只能传递常量。
PHP 允许参数按引用传递。在早期版本中,你可以通过为调用点添加修饰来指明变量按引用传递。在 PHP 5.4 中,该选项已被移除。相反,现代 PHP 编程只需要在函数声明时指定按引用传递即可。与 C# 不同,你不需要同时在声明和调用点指定按引用传递。

3.PHP 5.5中的新特性

3.1.PHP 5.5中的新特性

新特性及提案列表 都相当大,而且不是按重要性排序。所以,如果你不想通读一遍的话,这里有四个特点我个人是最兴奋的: 
:一个简单的密码散列API
:标量类型提示
:Getter和Setter   
:生成器
现在,让我们来看看PHP5.5 可能会新增的功能: 

3.1.1、放弃对Windows XP和2003 的支持

3.1.2.弃用e修饰符

e修饰符是指示preg_replace函数用来评估替换字符串作为PHP代码,而不只是仅仅做一个简单的字符串替换。不出所料,这种行为会源源不断的出现安全问题。这就是为什么在PHP5.5 中使用这个修饰符将抛出一个弃用警告。作为替代,你应该使用preg_replace_callback函数。你可以从RFC找到更多关于这个变化相应的信息。

3.1.3.新增函数和类

boolval()
PHP已经实现了strval、intval和floatval的函数。为了达到一致性将添加boolval函数。它完全可以作为一个布尔值计算,也可以作为一个回调函数。 
hash_pbkdf2()
PBKDF2全称“Password-Based Key Derivation Function 2”,正如它的名字一样,是一种从密码派生出加密密钥的算法。这就需要加密算法,也可以用于对密码哈希。更广泛的说明和用法示例
array_column()
//从数据库获取一列,但返回是数组。
$userNames = [];
foreach ($users as $user) {
    $userNames[] = $user['name'];
}
//以前获取数组某列值,现在如下
$userNames = array_column($users, 'name');
intl 扩展 
将有许多改进 intl的扩展。例如,将会有新的IntlCalendar,IntlGregorianCalendar,IntlTimeZone,IntlBreakIterator,IntlRuleBasedBreakIterator,IntlCodePointBreakIterator类。之前,我竟然不知道有这么多关于intl扩展,如果你想知道更多,我建议你去最新公告里找 Calendar和 BreakIterator。 


3.1.4.一个简单的密码散列API

$password = "foo";  
// creating the hash  
$hash = password_hash($password, PASSWORD_BCRYPT);  
// verifying a password  
if (password_verify($password, $hash)) {  
    // password correct!  
} else {  
    // password wrong!  
} 

3.1.5.新的语言特性和增强功能。

常量引用
“常量引用”意味着数组可以直接操作字符串和数组字面值。举两个例子:
function randomHexString($length) {  
    $str = '';  
    for ($i = 0; $i 我不认为在实践中会使用此功能,但它使语言更加一致。请参阅 RFC。<br>
<h4>3.1.6.调用empty()函数(和其他表达式)一起工作</h4>
目前,empty()语言构造只能用在变量,而不能在其他表达式。<br>
在特定的代码像empty($this->getFriends())将会抛出一个错误。作为PHP5.5 这将成为有效的代码<br>
<h4>3.1.7.获取完整类别名称</h4>
PHP5.3 中引入命名空间的别名类和命名空间短版本的功能。虽然这并不适用于字符串类名称<br>
<pre class="brush:php;toolbar:false">use Some\Deeply\Nested\Namespace\FooBar;  
// does not work, because this will try to use the global `FooBar` class  
$reflection = new ReflectionClass('FooBar'); 
echo FooBar::class;
为了解决这个问题采用新的FooBar::class语法,它返回类的完整类别名称

3.1.8.参数跳跃 

如果你有一个函数接受多个可选的参数,目前没有办法只改变最后一个参数,而让其他所有参数为默认值。 
RFC上的例子,如果你有一个函数如下: 
function create_query($where, $order_by, $join_type='', $execute = false, $report_errors = true) { ... }
那么有没有办法设置$report_errors=false,而其他两个为默认值。为了解决这个跳跃参数的问题而提出: 
create_query("deleted=0", "name", default, default, false);
我个人不是特别喜欢这个提议。在我的眼睛里,代码需要这个功能,只是设计不当。函数不应该有12个可选参数。 

3.1.9.标量类型提示 

标量类型提示原本计划进入5.4,但由于缺乏共识而没有做。获取更多关于为什么标量类型提示没有做进PHP的信息,请参阅: 标量类型提示比你认为的更难。 
对于PHP5.5 而言,针对标量类型提示讨论又一次出现,我认为这是一个相当不错的 提议。 
它需要通过输入值来指定类型。例如:123,123.0,“123”都是一个有效的int参数输入,但“hello world”就不是。这与内部函数的行为一致。 
function foo(int $i) { ... }
foo(1);      // $i = 1
foo(1.0);    // $i = 1
foo("1");    // $i = 1
foo("1abc"); // not yet clear, maybe $i = 1 with notice
foo(1.5);    // not yet clear, maybe $i = 1 with notice
foo([]);     // error
foo("abc");  // error

3.1.10.Getter 和 Setter 

如果你从不喜欢写这些getXYZ()和setXYZ($value)方法,那么这应该是你最受欢迎的改变。提议添加一个新的语法来定义一个属性的设置/读取: 
<?php class TimePeriod {
    public $seconds;
    public $hours {
        get { return $this->seconds / 3600; }
        set { $this->seconds = $value * 3600; }
    }
}
$timePeriod = new TimePeriod;
$timePeriod->hours = 10;
var_dump($timePeriod->seconds); // int(36000)
var_dump($timePeriod->hours);   // int(10)
当然还有更多的功能,比如只读属性。如果你想要知道更多,请参阅 RFC。 

3.1.11.生成器 yield

目前,自定义迭代器很少使用,因为它们的实现,需要大量的样板代码。生成器解决这个问题,并提供了一种简单的样板代码来创建迭代器。 
例如,你可以定义一个范围函数作为迭代器: 
<?php function *xrange($start, $end, $step = 1) {
    for ($i = $start; $i < $end; $i += $step) {
        yield $i;
    }
}
foreach (xrange(10, 20) as $i) {
    // ...
}
上述xrange函数具有与内建函数相同的行为,但有一点区别:不是返回一个数组的所有值,而是返回一个迭代器动态生成的值。 

3.1.12.列表解析和生成器表达式 

列表解析提供一个简单的方法对数组进行小规模操作: 
$firstNames = [foreach ($users as $user) yield $user->firstName];
上述列表解析相等于下面的代码: 
$firstNames = [];
foreach ($users as $user) {
    $firstNames[] = $user->firstName;
}
也可以这样过滤数组: 
$underageUsers = [foreach ($users as $user) if ($user->age 生成器表达式也很类似,但是返回一个迭代器(用于动态生成值)而不是一个数组。 <br>
<br>
以上来自:http://www.oschina.net/question/157182_61259<br>
<h4>3.1.13.finally关键字</h4>
这个和java中的finally一样,经典的try ... catch ... finally 三段式异常处理。<br>
<h4>3.1.14.foreach 支持list()</h4>
对于“数组的数组”进行迭代,之前需要使用两个foreach,现在只需要使用foreach + list了,但是这个数组的数组中的每个数组的个数需要一样。看文档的例子一看就明白了。<br>
<pre class="brush:php;toolbar:false">$array = [
    [1, 2],
    [3, 4],
];
foreach ($array as list($a, $b)) {
    echo "A: $a; B: $b\n";
}

3.1.15.增加了opcache扩展

使用opcache会提高php的性能,你可以和其他扩展一样静态编译(--enable-opcache)或者动态扩展(zend_extension)加入这个优化项。

3.1.16.非变量array和string也能支持下标获取了

echo array(1, 2, 3)[0];
echo [1, 2, 3][0];
echo "foobar"[2];

4.PHP5.6

原文连接http://cn2.php.net/manual/zh/migration56.new-features.php

4.1 常量增强

允许常量计算,允许使用包含数字、字符串字面值和常量的标量表达式

const A = 2;
const B = A + 1;
class C
{
    const STR = "hello";
    const STR2 = self::STR + ", world";
}
允许常量作为函数参数默认
function test($arg = C::STR2)

4.2 可变函数参数

代替 func_get_args()

function add(...$args)
{
    $result = 0;
    foreach($args as $arg)
        $result += $arg;
    return $result;
}

4.3 参数解包功能

在调用函数的时候,通过 ... 操作符可以把数组或者可遍历对象解包到参数列表,这和Ruby等语言中的扩张(splat)操作符类似
function add($a, $b, $c) {
    return $a + $b + $c;
}
$arr = [2, 3];
add(1, ...$arr);

4.4 命名空间 use 操作符开始支持函数和常量的导入

namespace Name\Space {
    const FOO = 42;
    function f() { echo __FUNCTION__."\n"; }
}
namespace {
    use const Name\Space\FOO;
    use function Name\Space\f;

    echo FOO."\n";
    f();
}
输出
42
Name\Space\f

4.5 使用**操作符计算乘方

4.6 phpdbg

PHP自带了一个交互式调试器phpdbg,它是一个SAPI模块,更多信息参考 phpdbg文档 。

4.7 php://input 可以被复用

php://input 开始支持多次打开和读取,这给处理POST数据的模块的内存占用带来了极大的改善。


4.8 大文件上传支持

可以上传超过2G的大文件。

4.9 GMP支持操作符重载

GMP 对象支持操作符重载和转换为标量,改善了代码的可读性,如:
<?php $a = gmp_init(42);
$b = gmp_init(17);
 
// Pre-5.6 code:
var_dump(gmp_add($a, $b));
var_dump(gmp_add($a, 17));
var_dump(gmp_add(42, $b));


// New code:
var_dump($a + $b);
var_dump($a + 17);
var_dump(42 + $b);

4.10 新增gost-crypto哈希算法

采用CryptoPro S-box tables实现了 gost-crypto 哈希算法,详情参考 RFC 4357, div 11.2 。

4.11 SSL/TLS改进

OpenSSL扩展新增证书指纹的提取和验证功能, openssl_x509_fingerprint()用于提取X.509证书的指纹,SSL stream context 选项: capture_peer_cert 用于获取对方X.509证书; peer_fingerprint 用于断言对方证书和给定的指纹匹配。


另外,可以通过SSL流上下文选项 crypto_method 指定加密方法,如SSLv3或TLS,目前支持的选项值包括STREAM_CRYPTO_METHOD_SSLv2_CLIENT, STREAM_CRYPTO_METHOD_SSLv3_CLIENT, STREAM_CRYPTO_METHOD_SSLv23_CLIENT (默认), or STREAM_CRYPTO_METHOD_TLS_CLIENT。





Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn