開始介紹PHP7.0新特性,具體的能夠參照官網的介紹,我來挑一些給你們詳細講解下php
$a = $_GET['a'] ?? 1;
它至關於:python
$a = empty($_GET['a']) ? 1 : $_GET['a'];
咱們知道三元運算符是能夠這樣用的:數組
$a ?: 1
可是這是創建在 $a 已經定義了的前提上。新增的 ?? 運算符能夠簡化判斷。簡化代碼的同時也更直觀了!閉包
官方文檔提供的例子(注意 ...
的邊長參數語法在 PHP 5.6 以上的版本中才有):composer
<?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。spa
強制模式:.net
<?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 註冊的自動加載方法是在類被調用的時候根據類的命名空間去查找位置,這種寫法對其沒有影響。
再來簡單說幾個:
一、PHP 5.3 開始有了匿名函數,如今又有了匿名類了;
二、define 如今能夠定義常量數組;
三、閉包( Closure)增長了一個 call 方法;
四、生成器(或者叫迭代器更合適)能夠有一個最終返回值(return),也能夠經過 yield from
的新語法進入一個另一個生成器中(生成器委託)。
生成器的兩個新特性(return 和 yield from
)能夠組合。具體的你們能夠自行測試。