1. ?? 運算子(NULL 合併運算子)
$a = $_GET['a'] ?? 1;
它相當於:
$a = empty($_GET['a']) ? 1 : $_GET['a'];
我們知道三元運算符是可以這樣用的:
$a ?: 1
但是這是建立在$a 已經定義了的前提上。新增的 ?? 運算子可以簡化判斷。簡化程式碼的同時也更直觀了!
官方文件提供的範例(注意 ...
的邊長參數語法在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
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
的致命錯誤。
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
)可以組合。具體的大家可以自行測試。
以上是php7新增標量,運算符,傳回值類型的特性詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!