php 7.0 特性

https://segmentfault.com/a/1190000003893899

截止到目前为止,PHP官方已经发布了php7的RC7版本,距离发布第一个正式版本不会很远了!现在来说php7的重大特性肯定已经是定型了,不会再有什么变动了。后续一些版本的迭代主要也就是修修bug,优化之类的。下面就来说话我们一直期待的php7会有那些主要的变化了。。。

关于PHP

  • 20年的发展历史;

  • 迄今为止最流行的WEB开发语言;

  • 超过82%的网站都会使用PHP作为他们的服务端开发语言;

新特性介绍

  • PHP NG – Zend Engine 3

  • 抽象语法树

  • 64位的 INT 支持

  • 统一的变量语法

  • 新增Closure::call()

  • 一致性foreach循环

  • 匿名类的支持

  • 新增 <=>**??\u{xxxx}操作符

  • 增加了返回类型的声明

  • 增加了标量类型的声明

  • 核心错误可以通过异常捕获

  • 增加了上下文敏感的词法分析

PHP NG

  • ZVAL

大小从24字节减少到16字节

  • Zend Array(HashTable)

HashTable大小从72字节减少到56字节
HashTable bucket大小从72字节减少到32字节

  • 函数调用的优化

  • 使用了新的内存分配,管理方式,减少了内存的浪费

  • Immutable array optimization

    $arr = [];
    
    for($i=0; $i<100000; $i++) {
        $arr[] = ['php'];
    }
    
    p(memory_get_usage(true));

PHP5: 45M
PHP7: 10M

  • 一些非常常用,开销不大的的函数直接变成了引擎支持的opcode

call_user_function(_array) => ZEND_INIT_USER_CALL
is_intis_stringis_array、... => ZEND_TYPE_CHECK
strlen => ZEND_STRLEN
defined => ZEND+DEFINED

  • 核心排序的优化

PHP5(zend_qsort
快速排序(非稳定排序)

array(1 => 0, 0 => 0)

PHP7(zend_sort
快速排序+选择排序(稳定排序)

array(0 => 0, 1 => 0)

小于16个元素的使用选择排序,大于16个按照16个为单位去分割,分别使用选择排序,然后再全部合起来使用快速排序。排序较之前相比,内部元素由非稳定排序变成稳定排序,减少元素的交换次数,减少对内存的操作次数,性能提升40%

抽象语法树

假如现在我们有这样的需求,要对php源文件就行语法检测,实现编码规范。php5之前的话,没有AST,直接从parser就生成了opcodes!就需要借助一些外部的php语法解析器来实现;而php7增加了AST,我们可以自己去实现这样一个扩展,利用扩展提供的函数可以直接获取文件对应的的AST结构,而这样的结构正是我们可以识别的,所以就可以在这个基础上去做一些优化和判断了。

64位的INT支持

  • 支持存储大于2GB的字符串

  • 支持上传大小大于2GB的文件

  • 保证字符串在所有平台上【64位】都是64bit

统一的语法变量

$$foo['bar']['baz'] 

PHP5: ${$foo[‘bar’]['baz']}
PHP7: ($$foo)[‘bar’][‘baz']【从左至右法则】

(function() {})();
$foo()();
[$obj, 'method']();

class A {
    public static function a1() {}
}

[new A, 'a1']();

新增Closure::call()

$f = function() {
    p($this->name);
};

class F {
    private $name = 'F';
}

$f->call(new F);

匿名类的支持

function getAnonymousClass($config) {
    return new class(config) {};
 }

p(getAnonymousClass(array()));

一致性的foreach循环

//PHP5
$a =  array(1, 2, 3);foreach ($a as $v){var_dump(current($a));}
int(2)
int(2)
int(2)

$a =  array(1, 2, 3);$b=&$a;foreach ($a as $v){var_dump(current($a));}
int(2)
int(3)
bool(false)

$a =  array(1, 2, 3);$b=$a;foreach ($a as $v){var_dump(current($a));}
int(1)
int(1)
int(1)

//PHP7:不再操作数据的内部指针了
$a =  array(1, 2, 3);foreach ($a as $v){var_dump(current($a))}
int(1)
int(1)
int(1)

$a =  array(1, 2, 3);$b=&$a;foreach ($a as $v){var_dump(current($a))
int(1)
int(1)
int(1)

$a =  array(1, 2, 3);$b=$a;foreach ($a as $v){var_dump(current($a))}
int(1)
int(1)
int(1)

新增的几个操作符

<=>

//PHP5
function compare($a, $b) {
    return ($a < $b) ? -1 : (($a >$b) ? 1 : 0);
}
//PHP7
function compare($a, $b) {
    return $a <=> $b;
}

**

2 ** 2; // 2 * 2 = 4
2 ** -1; // 1 / 2 = 0.5
3 ** -2; // 1 / 9 = 0.111111111

??

$a = null;
$b = 1;
$c = 2;
echo $a ?? $b , ‘,’ , $c ?? $b; // 1,2
echo $a ?? $b ?? $c  , ‘,’ , $a ?? $d ?? $c; // 1,2

\u{xxxx}

echo "\u{4f60}";//你
echo "\u{65b0}";//新
// 从右至左强制
echo"\u{202E}iabgnay\u{1F602}";;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值