這篇文章主要介紹了PHP 7.0新增加的特性介紹,需要的朋友可以參考下
#?? 運算子(NULL 合併運算子) 把這個放在第一個說是因為我覺得它很有用。用法: $a = $_GET['a'] ?? 1;它相當於: a1190868ae169845c0633014bbe0dbfc String { let greeting = "Hello, " + personName + "!" return greeting } 這個特性可以幫助我們避免一些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
在宣告之後,就會觸發致命錯誤。
有點類似 js 的 strict mode?
標量類型宣告
#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 的致命錯誤。
1.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 註冊的自動載入方法是在類別被呼叫的時候根據類別的命名空間去查找位置,這種寫法對其沒有影響。
其他的特性
其他的一些特性我就不一一介紹了,有興趣可以查看官方文件:http ://php.net/manual/en/migration70.new-features.php
#簡單說幾個:
##PHP 5.3 開始有了匿名函數,現在又有了匿名類別了; define 現在可以定義常數數組; 閉包( Closure)增加了一個call 方法; 生成器(或者叫迭代器更合適)可以有一個最終返回值(return) ,也可以透過yield from 的新語法進入一個另一個生成器中(生成器委託)。 生成器的兩個新特性(return 和 yield from)可以組合。具體的表像大家可以自行測試。 PHP 7 現在已經到 RC5 了,最終的版本應該很快就會到來。以上是簡單介紹PHP 7.0新增加的特性的詳細內容。更多資訊請關注PHP中文網其他相關文章!