[译] PHP5.6的新特性

    原文链接:http://www.sitepoint.com/new-features-php-5-6/

    前面两段是作者吐槽PHP核心开发者的。。我们看重点。。此处省略500字。。。

    CLI服务器中得MIME类型

    MIME类型在php中用于输出其他非PHP类型的内容,也就是说你可以输出一个不是text/html类型的内容。当你执行一个PHP页面,默认输出的是text/html,但是你能用headers去设置他。例如PDF和生成PDF,因为通常的服务器都是HHVM,nginx,apache等,所以当服务器知道是一个不同的MIME类型,服务器知道怎样去根据文件的后缀去给他一个默认类型。而不必跑到PHP中去确认。从PHP5.4的命令行服务器只有几个MIME至今,这个版本将要扩充到几十个。可以肯定的说,所有的MIME类型都将内置在PHP服务器当中了。

    内建运算符重载

    这个功能对于用PHP来做web开发的开发者来说应该接触不到,因为是“内部”的。内部的意思是:非用户空间中得,用户空间是PHP开发者们使用的区域。只有内部类使用他,以使开发更加简洁和可读性更好。在这里有更详细的解释。

    现在可以上传超过2G的文件    

    知道5.6,之前所有的PHP版本上传文件都不可以超过2G,这已经是过去式了。新版的changelog表明,现在已经支持上传任意大小的文件了。

    POST数据的内存使用量下降

    POST数据的内存使用量已经下降了2-3倍,并且取消了这两个设置:always_populate_raw_post_data 在 php.ini 里面的设置,以及 $HTTP_RAW_POST_DATA 这个超全局变量。这意味着你不能再用原来的方式访问post数据。需要依赖于另一种解决方案:

$postdata = file_get_contents("php://input");

 当这个表单被分成多个部分时,是无法用 ://input 获得POST的数据的(换句话说,如果这个表单中有一个文件域的话,就不行)

    改进可变参数函数的语法

    可变参数函数允许传入任意数量的参数。当你提供给他一些参数,你通常不得不调用 func_get_args 来进行后续操作,这有点不切实际。在这里有这样的例子,在5.5中语法是这样的:

class MySQL implements DB {
    protected $pdo;
    public function query($query) {
        $stmt = $this->pdo->prepare($query);
        $stmt->execute(array_slice(func_get_args(), 1));
        return $stmt;
    }
    // ...
}
 
$userData = $db->query('SELECT * FROM users WHERE id = ?', $userID)->fetch();

 现在语法将变成这样:

class MySQL implements DB {
    public function query($query, ...$params) {
        $stmt = $this->pdo->prepare($query);
        $stmt->execute($params);
        return $stmt;
    }
    // ...
}

 就像你看到的,…$params 语法将告诉这个方法,接受第一个参数,其他的全都放到$params数组当中。这样就使我们拜托了去调用 func_get_args ,改善了函数签名,并且可读性更高了。

并且这个新的语法还允许对额外的参数使用传递引用。 给 …$params 加一个&符前缀,就像这样 &...$params 这是 func_get_args 不可能做到的。

    参数解包

    注:感谢 nikic 指出这个功能,在这个文章写作的时候进行了落实。

    在改善可变参数函数之后,参数解包也得到了支持。

    到目前为止,通过参数的方式,调用一个方法的时候传入任意多个数量的参数的为止方式是使用 call_user_func_array 。字面意思就是“调用一个用户函数并使用一个array作为参数”。这很笨拙和不方便,而且不支持构造函数,速度慢,需要一个字符串形式的回调函数,这意味着大多数的IDE都不能跟踪和支持这个函数。

    解包功能将消除上面的所有的缺点,而且自然的补充了上面看到的任意数量参数的支持。解包看起来像这样:

$args = [1, 3, 5, 7, 9];
MyClass::someMethod(...$args);

 这样的方式就像是这样:

MyClass::someMethod(1, 3, 5, 7, 9);

 i.e. 通过这一个又一个的参数,使他可以工作在任何的场景下,从类的初始化到各种回调。详情看上面的RFC链接。

    常量表达式

    RFC在那种只需要静态值的地方增加了使用表达式的能力。这意味着你现在可以使用基本算数,逻辑结构,常数声明,方法参数,类属性等等。

    

const a = 1;
const b = a?2:100;

    现在已经不再是这样了。

    这个点上可能会存在争论对于常量真的是恒定的,如果他的值依赖于另一个常量。但是与其争论这个不如干点别的。

    PHPDBG被默认安装

     gdb-like debugger和phpdbg现在默认安装,作为SAPI。他在命令行或者一个简单的JAVA UI中使用,设置断点然后改变程序的运行。他还能检查Opcode,并在你的PHP代码中使用。学习更多phpdbg请点击这里

    改进ZIP

     Zip库在新的方法中专门做了几点改善。一个特别突出的是 ZipArchive::setPassword($password) 让你可以方便的为ZIP文件创建密码保护。

    引入命名空间功能

    按照这个RFC,这个新版本允许引入带命名空间的方法和常量。那么我们可以通过一个声明来引入命名空间类型(类,接口,traits)

namespace foo\bar {
    function baz() {
        return 'foo.bar.baz';
    }
}

namespace {
    use foo\bar as b;
    var_dump(b\baz());
}

 从5.6开始,我们可以使用 use function 和 use const 声明来引入一个独立的方法或常量(甚至是类常量)

namespace {
    use function foo\bar as foo_bar;
    use const foo\BAZ as FOO_BAZ;
    var_dump(foo_bar());
    var_dump(FOO_BAZ);
}