開始介紹PHP7.0新特性,具體的可以參照官網的介紹,我來挑一些給大家詳細講解下
http://php.net/manual/en/migration70.new-features.php
1. ?? 運算符(NULL 合並運算符)
$a = $_GET['a'] ?? 1;
它相當於:
$a = empty($_GET['a']) ? 1 : $_GET['a'];
我們知道三元運算符是可以這樣用的:
$a ?: 1
但是這是建立在 $a 已經定義了的前提上。新增的 ?? 運算符可以簡化判斷。簡化代碼的同時也更直觀了!
2. 函數返回值類型聲明
官方文檔提供的例子(注意 ...
的邊長參數語法在 PHP 5.6 以上的版本中才有):
<?php function arraysSum(array ...$arrays): array { return array_map(function(array $array): int { return array_sum($array); }, $arrays); } print_r(arraysSum([1,2,3], [4,5,6], [7,8,9]));
從這個例子中可以看出現在函數(包括匿名函數)都可以指定返回值的類型。
這個特性可以幫助我們避免一些 PHP 的隱式類型轉換帶來的問題。在定義一個函數之前就想好預期的結果可以避免一些不必要的錯誤。
不過這里也有一個特點需要注意。PHP 7 增加了一個 declare 指令:strict_types
,既使用嚴格模式。
使用返回值類型聲明時,如果沒有聲明為嚴格模式,如果返回值不是預期的類型,PHP 還是會對其進行強制類型轉換。但是如果是嚴格模式, 則會出發一個 TypeError
的 Fatal error。
強制模式:
<?php function foo($a) : int { return $a; } foo(1.0);
以上代碼可以正常執行,foo 函數返回 int 1,沒有任何錯誤。
嚴格模式:
<?php declare(strict_types=1); function foo($a) : int { return $a; } foo(1.0);
在聲明之后,就會觸發致命錯誤。
# PHP Fatal error: Uncaught TypeError: Return value of foo() must be of the type integer, float returned in test.php:6
3. 標量類型聲明
PHP 7 中的函數的形參類型聲明可以是標量了。在 PHP 5 中只能是類名、接口、array
或者 callable
(PHP 5.4,即可以是函數,包括匿名函數),現在也可以使用 string
、int
、float
和 bool
了。
<?php // Coercive mode function sumOfInts(int ...$ints) { return array_sum($ints); } var_dump(sumOfInts(2, '3', 4.1));
需要注意的是上文提到的嚴格模式的問題在這里同樣適用:強制模式(默認,既強制類型轉換)下還是會對不符合預期的參數進行強制類型轉換,嚴格模式下則觸發 TypeError
的致命錯誤。
4. use 批量聲明
PHP 7 中 use 可以在一句話中聲明多個類或函數或 const 了:
<?php use some\namespace\{ClassA, ClassB, ClassC as C}; use function some\namespace\{fn_a, fn_b, fn_c}; use const some\namespace\{ConstA, ConstB, ConstC};
但還是要寫出每個類或函數或 const 的名稱(並沒有像 python 一樣的 from some import *
的方法)。
需要留意的問題是:如果你使用的是基於 composer 和 PSR-4 的框架,這種寫法是否能成功的加載類文件?其實是可以的,composer 注冊的自動加載方法是在類被調用的時候根據類的命名空間去查找位置,這種寫法對其沒有影響。
再來簡單說幾個:
1、PHP 5.3 開始有了匿名函數,現在又有了匿名類了;
2、define 現在可以定義常量數組;
3、閉包( Closure)增加了一個 call 方法;
4、生成器(或者叫迭代器更合適)可以有一個最終返回值(return),也可以通過 yield from
的新語法進入一個另外一個生成器中(生成器委托)。
生成器的兩個新特性(return 和 yield from
)可以組合。具體的大家可以自行測試。