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

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云解析 DNS,旗舰版 1个月
简介: 因为用到PHP新版本,一些新特性必须要了解,且有些可以在开发时就使用,如果不使用,那么何必升级PHP版本呢,显得有些得不偿失了!所以整理了一下 一些特性,有可能不全,待添加 PHP7.0 和PHP7.1.X新特性请看 http://blog.csdn.net/fenglailea/article/details/52717364 1.PHP 5.3中的新特性  1.1 PHP 5.3
因为用到PHP新版本,一些新特性必须要了解,且有些可以在开发时就使用,如果不使用,那么何必升级PHP版本呢,显得有些得不偿失了!

所以整理了一下 一些特性,有可能不全,待添加

PHP7.0 和PHP7.1.X新特性请看 http://blog.csdn.net/fenglailea/article/details/52717364

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('select.php');  
$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 'Foo';  
a:  
echo 'Bar';  
for($i=0,$j=50; $i<100; $i++) {  
  while($j--) {  
    if($j==17) goto end;  
  }   
}  
echo "i = $i";  
end:  
echo 'j hit 17';

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('~-([a-z])~', function ($match) {  
    return strtoupper($match[1]);  
}, 'hello-world');  
// 输出 helloWorld  
$greet = function($name)  
{  
    printf("Hello %s\r\n", $name);  
};  
$greet('World');  
$greet('PHP');  
//...在某个类中  
$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 "调用对象方法 '$name' "  
             . implode(' -- ', $arguments). "\n";  
    }  
    /**  PHP 5.3.0 以上版本中本类方法有效  */  
    public static function __callStatic($name, $arguments) {  
        // 参数 $name 大小写敏感  
        echo "调用静态方法 '$name' "  
             . implode(' -- ', $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 '$name' "  
             . implode(', ', $arguments). "\n";  
    }  
  
    /**  PHP 5.3.0 以上版本中本类方法有效  */  
    public static function __callStatic($name, $arguments) {  
        // 参数 $name 大小写敏感  
        echo "Calling static method '$name' "  
             . implode(', ', $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 = 'MyName';  
echo <<<'EOT'  
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 < $length; ++$i) {  
        $str .= "0123456789abcdef"[mt_rand(0, 15)]; // direct dereference of string  
    }  
}  
function randomBool() {  
    return [false, true][mt_rand(0, 1)]; // direct dereference of array  
} 
我不认为在实践中会使用此功能,但它使语言更加一致。请参阅 RFC。

3.1.6.调用empty()函数(和其他表达式)一起工作

目前,empty()语言构造只能用在变量,而不能在其他表达式。
在特定的代码像empty($this->getFriends())将会抛出一个错误。作为PHP5.5 这将成为有效的代码

3.1.7.获取完整类别名称

PHP5.3 中引入命名空间的别名类和命名空间短版本的功能。虽然这并不适用于字符串类名称
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 < 18) yield $user];
生成器表达式也很类似,但是返回一个迭代器(用于动态生成值)而不是一个数组。 

以上来自:http://www.oschina.net/question/157182_61259

3.1.13.finally关键字

这个和java中的finally一样,经典的try ... catch ... finally 三段式异常处理。

3.1.14.foreach 支持list()

对于“数组的数组”进行迭代,之前需要使用两个foreach,现在只需要使用foreach + list了,但是这个数组的数组中的每个数组的个数需要一样。看文档的例子一看就明白了。
$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

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, section 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。





相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
7天前
|
缓存 PHP 开发者
PHP 7新特性及其影响
本文主要介绍了PHP 7的新特性以及这些新特性对开发者和项目的影响。文章详细解析了PHP 7的性能提升、类型声明、空合并运算符等新特性,并讨论了如何利用这些新特性来优化代码。同时,文章也探讨了这些新特性可能带来的问题和挑战,如兼容性问题和学习成本等。最后,文章以一个实际的代码示例来展示如何使用PHP 7的新特性来优化代码。
12 1
|
13天前
|
编译器 PHP 开发者
PHP 8新特性解析与实战应用####
随着PHP 8的发布,这一经典编程语言迎来了诸多令人瞩目的新特性和性能优化。本文将深入探讨PHP 8中的几个关键新功能,包括命名参数、JIT编译器、新的字符串处理函数以及错误处理改进等。通过实际代码示例,展示如何在现有项目中有效利用这些新特性来提升代码的可读性、维护性和执行效率。无论你是PHP新手还是经验丰富的开发者,本文都将为你提供实用的技术洞察和最佳实践指导。 ####
25 1
|
23天前
|
PHP 开发者
PHP 7新特性深度解析
【10月更文挑战第40天】随着PHP 7的发布,这个广泛使用的语言带来了许多令人兴奋的新特性和性能改进。本文将深入探讨PHP 7的主要变化,包括类型声明、错误处理机制、性能优化等方面,帮助开发者更好地理解和应用这些新特性。
29 4
|
1月前
|
PHP 开发者
PHP 7新特性深度解析及其最佳实践
【10月更文挑战第31天】本文将深入探讨PHP 7带来的革新,从性能提升到语法改进,再到错误处理机制的变革。我们将通过实际代码示例,展示如何高效利用这些新特性来编写更加健壮和高效的PHP应用。无论你是PHP新手还是资深开发者,这篇文章都将为你打开一扇窗,让你看到PHP 7的强大之处。
|
1月前
|
安全 编译器 PHP
PHP 8新特性解析与实践应用####
————探索PHP 8的创新功能及其在现代Web开发中的实际应用
|
2月前
|
PHP 数据安全/隐私保护 开发者
PHP 7新特性解析与实践
【10月更文挑战第20天】本文将深入浅出地介绍PHP 7的新特性,包括性能提升、语法改进等方面。我们将通过实际代码示例,展示如何利用这些新特性优化现有项目,提高开发效率。无论你是PHP新手还是资深开发者,都能从中获得启发和帮助。
|
2月前
|
安全 编译器 PHP
PHP 7新特性深度解析与实践
【10月更文挑战第7天】在这篇文章中,我们将探索PHP 7带来的新特性和改进,以及如何利用这些新工具来提升你的代码效率。从性能优化到语法简化,再到错误处理的改进,本文将带你深入了解PHP 7的核心变化,并通过实际代码示例展示如何将这些新特性应用到日常开发中。无论你是PHP新手还是资深开发者,这篇文章都将为你提供有价值的见解和技巧。
43 6
|
2月前
|
安全 编译器 API
探索PHP 8的新特性及其对现代Web开发的影响
【10月更文挑战第5天】随着PHP 8的发布,这门历史悠久的脚本语言重获新生。PHP 8引入了联合类型、命名参数、属性、空安全运算符及JIT编译器等一系列新特性,不仅提升了开发者的编程体验,还增强了PHP在现代Web开发领域的竞争力。本文将详细介绍这些新特性及其对Web开发的影响。例如,联合类型允许函数参数接受多种类型,提高代码灵活性;命名参数则使函数调用更加直观易懂;属性可用于装饰类、方法等,提供额外信息;空安全运算符避免了访问未定义属性时的错误;JIT编译器则显著提升了性能。这些改进共同提升了代码质量和开发效率,巩固了PHP在Web开发中的地位。
24 4
|
2月前
|
缓存 安全 PHP
PHP 7新特性及其最佳实践
【10月更文挑战第2天】本文将深入探讨PHP 7带来的创新特性,以及如何运用这些特性优化代码和提升性能。我们将从类型声明、空值合并运算符等新语法出发,通过实际代码示例,展示如何高效利用PHP 7的新特性进行开发。文章还将分享一系列最佳实践,帮助你写出更安全、更快速的PHP代码。无论你是PHP新手还是资深开发者,这篇文章都将为你提供有价值的见解和技巧。
41 5
|
2月前
|
安全 编译器 API
探索PHP 8的新特性及其对现代Web开发的影响
探索PHP 8的新特性及其对现代Web开发的影响
19 0