PHP7新特性

1.类型的声明。

可以使用字符串(string),整数(int),浮点数(float),以及布尔值(bool),来声明函数的参数类型与函数返回值。

  1. declare(strict_types=1);

  2. function add(int $a, int $b): int {

  3. return $a+$b;

  4. }

  5.  
  6. echo add(1, 2);

  7. echo add(1.5, 2.6);

php5是无法执行上面代码的,php7执行的时候会先输出一个3和一个报错(传递给add()的参数1必须是integer类型,float给出);

标量类型声明有两种模式:强制(默认)和严格模式 
.sencere(strict_types = 1),必须放在文件的第一行执行代码,当前文件有效!

2.set_exception_handler()不再保证收到的一定是Exception对象

在PHP 7中,很多致命错误以及可恢复的致命错误,都被转换为异常来处理了。这些异常继承自错误类,此类实现了Throwable接口(所有异常都实现了这个基础接口)。

PHP7进一步方便开发者处理,让开发者对程序的掌控能力更强。因为在默认情况下,错误会直接导致程序中断,而PHP7则提供捕获并且处理的能力,让程序继续执行下去,为程序员提供更灵活的选择。

3.新增操作符“<=>”

语法:$ c = $ a <=> $ b

如果$ a> $ b,$ c的值为1

如果$ a == $ b,$ c的值为0

如果$ a <$ b,$ c的值为-1

4.新增操作符“??”

如果变量存在且值不为NULL,它就会返回自身的值,否则返回它的第二个操作数。

  1. //原写法

  2. $username = isset($_GET['user]) ? $_GET['user] : 'nobody';

  3.  
  4. //现在

  5. $username = $_GET['user'] ?? 'nobody';

5.define()定义常量数组

  1. define('ARR',['a','b']);

  2. echo ARR[1];// a

6.AST:抽象语法树,抽象语法树

AST在PHP编译过程作为一个中间件的角色,替换原来直接从解释器吐出操作码的方式,让解释器(解析器)和编译器(compliler)解耦,可以减少一些Hack代码,同时,让实现更容易理解和可维护。

PHP5:PHP代码 - > Parser语法解析 - > OPCODE - >执行 
PHP7:PHP代码 - > Parser语法解析 - > AST - > OPCODE - >执行

参考:https:  //wiki.php.net/rfc/abstract_syntax_tree

7.匿名函数

  1. $anonymous_func = function(){return 'function';};

  2. echo $anonymous_func(); // 输出function

8.Unicode字符格式支持(echo“\ u {9999}”)

9.Unserialize提供过滤特性

防止非法数据进行代码注入,提供了更安全的反序列化数据。

10.命名空间引用优化

  1. // PHP7以前语法的写法

  2. use FooLibrary\Bar\Baz\ClassA;

  3. use FooLibrary\Bar\Baz\ClassB;

  4. // PHP7新语法写法

  5. use FooLibrary\Bar\Baz\{ ClassA, ClassB};

PHP7带来的废弃

1.废弃扩展

Ereg正则表达式 
mssql 
mysql 
sybase_ct

2.废弃的特性

使用不能同名的构造函数 
实例方法不能用静态方法的方式调用

3.废弃的函数

方法调用 
call_user_method() 
call_user_method_array()

应该采用call_user_func()和call_user_func_array()

加密相关函数

mcrypt_generic_end() 
mcrypt_ecb() 
mcrypt_cbc() 
mcrypt_cfb() 
mcrypt_ofb()

注意:PHP7.1以后mcrypt_ *序列函数都将被移除。推荐使用:openssl序列函数

杂项

set_magic_quotes_runtime 
set_socket_blocking 
分割 
imagepsbbox() 
imagepsencodefont() 
imagepsextendfont() 
imagepsfreefont() 
imagepsloadfont() 
imagepsslantfont() 
imagepstext()

4.废弃的用法

$ HTTP_RAW_POST_DATA变量被移除,使用php://输入来代

ini文件里面不再支持#开头的注释,使用“;”

移除了ASP格式的支持和脚本语法的支持:<%和<script language = php>

PHP7带来的变更

1.字符串处理机制修改

含有十六进制字符的字符串不再视为数字,也不再区别对待。

  1. var_dump("0x123" == "291"); // false

  2. var_dump(is_numeric("0x123")); // false

  3. var_dump("0xe" + "0x1"); // 0

  4. var_dump(substr("f00", "0x1")) // foo

2.整型处理机制修改

Int64支持,统一不同平台下的整型长度,字符串和文件上传都支持大于2GB。64个PHP7字符串长度可以超过2 ^ 31次方字节。

// 无效的八进制数字(包含大于7的数字)会报编译错误

$i = 0681; // 老版本php会把无效数字忽略。

// 位移负的位置会产生异常

var_dump(1 >> -1);

// 左位移超出位数则返回0

var_dump(1 << 64);// 0

// 右位移超出会返回0或者-1

var_dump(100 >> 32);// 0

var_dump(-100 >> 32);// -1

3.参数处理机制修改

不支持重复参数命名

function func(b,c){}; hui报错

func_get_arg()和func_get_args()这两个方法返回参数当前的值,而不是传入时的值,当前的值有可能会被修改

所以需要注意,在函数第一行最好就给记录下来,否则后续有修改的话,再读取就不是传进来的初始值了。

  1. function foo($x) {

  2. $x++;

  3. echo func_get_arg(0);

  4. }

  5. foo(1); //返回2

4.foreach修改

的foreach()循环对数组内部指针不再起作用

$arr = [1,2,3];

foreach ($arr as &$val) {

echo current($arr);// php7 全返回0

}

按照值进行循环的时候,foreach是对该数组的拷贝操作

$arr = [1,2,3];

foreach ($arr as $val) {

unset($arr[1]);

}

var_dump($arr);

最新的PHP7依旧会打印出[1,2,3](PS:7.0.0不行)。 
老的会打印出[1,3]

按照引用进行循环的时候,对数组的修改会影响循环

$arr = [1];

foreach ($arr as $val) {

var_dump($val);

$arr[1]=2;

}

最新的PHP7依旧会追加新增元素的循环(PS:7.0.0不行)。

5.列出修改

不再按照相反的顺序赋值

//$arr将会是[1,2,3]而不是之前的[3,2,1]

list($arr[], $arr[], $arr[]) = [1,2,3];

不再支持字符串拆分功能

// $x = null 并且 $y = null

$str = 'xy';

list($x, $y) = $str;

空的列表()赋值不再允许

list() = [123];

名单()现在也适用于数组对象

list($a, $b) = (object)new ArrayObject([0, 1]);

6.变量处理机制修改

对变量,属性和方法的间接调用现在将严格遵循从左到右的顺序来解析,而不是之前的混杂着几个特殊案例的情况。下面这张表说明了这个解析顺序的变化。

这里写图片描述

引用赋值时自动创建的数组元素或者对象属性顺序和以前不同了

$arr = [];

$arr['a'] = &$arr['b'];

$arr['b'] = 1;

// php7: ['a' => 1, 'b' => 1]

// php5: ['b' => 1, 'a' => 1]

7.杂项

1.debug_zval_dump()现在打印“int”替代“long”,打印“float”替代“double”

2.dirname()增加了可选的第二个参数,depth,获取当前目录向上深度级父目录的名称。

3.getrusage()现在支持Windows.mktime()和gmmktime()函数不再接受is_dst参数。

4.preg_replace()函数不再支持“\ e”(PREG_REPLACE_EVAL)。应当使用preg_replace_callback()替代。

5.setlocale()函数不再接受类别传入字符串。应当使用LC_ *常量。

6.exec(),system()和passthru()函数对NULL增加了保护。

7.shmop_open()现在返回一个资源而非一个int,这个资源可以传给shmop_size(),shmop_write(),shmop_read(),shmop_close()和shmop_delete()。

8.为了避免内存泄露,xml_set_object()现在在执行结束时需要手动清除$ parse。

9.curl_setopt设置项CURLOPT_SAFE_UPLOAD变更

TRUE禁用@前缀在CURLOPT_POSTFIELDS中发送文件。意味着@可以在字段中安全得使用了。可使用CURLFile作为上传的代替 
.PHP 5.5.0中添加,默认值FALSE。PHP 5.6.0改默认值为TRUE .. PHP 7删除了此选项,必须使用CURLFile接口来上传文件。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值