您好,登錄后才能下訂單哦!
這篇文章主要介紹“PHP8新特性有哪些及怎么使用”的相關知識,小編通過實際案例向大家展示操作過程,操作方法簡單快捷,實用性強,希望這篇“PHP8新特性有哪些及怎么使用”文章能幫助大家解決問題。
PHP作為一門已經存在了26年的編程語言,可以說是比較長壽的語言了。但是作為一門長壽的語言,他有些與時代脫節了。在運行效率上,不如C語言java語言這樣的編譯型語言。在安全性上因為使用的人數比較多,所以被發現漏洞的幾率也就越多。同時因為語法寬松,發現的漏洞也就更多了,最近版本的PHP7就曾爆出過重大漏洞,如果對安全有較高要求的話,PHP將不再是首選的語言。鑒于這些原因,PHP8的優化方向主要是性能和安全。
接下來我們來介紹一下PHP8的新特性,了解一下它做了什么更新。
如果你是初學者,不想關注php8的新特性,或者已經知道了這些新特性,可以直接跳過接下來的一大段介紹,但是相信我,看完這些介紹你會對PHP有一個大的改觀。
在PHP7中,命名參數的寫法為:
htmlspecialchars($string, ENT_COMPAT | ENT_HTML401, 'UTF-8', false);
在PHP8中,命名參數優化為:
htmlspecialchars($string, double_encode: false);
僅僅指定必填參數,跳過可選參數。
參數的順序無關、自己就是文檔(self-documented)
在PHP7中,注解的寫法為:
class PostsController
{
/**
* @Route("/api/posts/{id}", methods={"GET"})
*/
public function get($id) { /* ... */ }
}
在PHP8中,注解寫法優化為:
class PostsController
{
#[Route("/api/posts/{id}", methods: ["GET"])]
public function get($id) { /* ... */ }
}
現在可以用 PHP 原生語法來使用結構化的元數據,而非 PHPDoc 聲明。
在PHP7中,構造器的寫法為:
class Point {
public float $x;
public float $y;
public float $z;
public function __construct(
float $x = 0.0,
float $y = 0.0,
float $z = 0.0
) {
$this->x = $x;
$this->y = $y;
$this->z = $z;
}
}
在PHP8中,構造器的寫法優化為:
class Point {
public function __construct(
public float $x = 0.0,
public float $y = 0.0,
public float $z = 0.0,
) {}
}
現在可以用更少的樣板代碼來定義并初始化屬性。
在PHP7中,聯合類型的寫法為:
class Number {
/** @var int|float */
private $number;
/**
* @param float|int $number
*/
public function __construct($number) {
$this->number = $number;
}
}
new Number('NaN'); // Ok
在PHP8中,聯合類型的寫法優化為:
class Number {
public function __construct(
private int|float $number
) {}
}
new Number('NaN'); // TypeError
相較于以前的 PHPDoc 聲明類型的組合, 現在可以用原生支持的聯合類型聲明取而代之,并在運行時得到校驗。
在PHP7中,match表達式的寫法為:
switch (8.0) {
case '8.0':
$result = "Oh no!";
break;
case 8.0:
$result = "This is what I expected";
break;
}
echo $result;
//> Oh no!
在PHP8中,match表達式的寫法優化為:
echo match (8.0) {
'8.0' => "Oh no!",
8.0 => "This is what I expected",
};
//> This is what I expected
新的 match 類似于 switch,并具有以下功能:
Match 是一個表達式,它可以儲存到變量中亦可以直接返回。
Match 分支僅支持單行,它不需要一個 break; 語句。
Match 使用嚴格比較。
在PHP7中,nullsafe運算符的寫法為:
$country = null;
if ($session !== null) {
$user = $session->user;
if ($user !== null) {
$address = $user->getAddress();
if ($address !== null) {
$country = $address->country;
}
}
}
在PHP8中,Nullsafe運算符的寫法優化為:
$country = $session?->user?->getAddress()?->country;
現在可以用新的 nullsafe 運算符鏈式調用,而不需要條件檢查 null。 如果鏈條中的一個元素失敗了,整個鏈條會中止并認定為 Null。
在PHP7中,字符串與數字的比較邏輯是這樣的:
0 == 'foobar' // true
在PHP8中,字符串與數字的比較邏輯是這樣的:
0 == 'foobar' // false
PHP 8 比較數字字符串(numeric string)時,會按數字進行比較。 不是數字字符串時,將數字轉化為字符串,按字符串比較。
在PHP7中,內部函數類型錯誤是這樣的:
strlen([]); // Warning: strlen() expects parameter 1 to be string, array given
array_chunk([], -1); // Warning: array_chunk(): Size parameter expected to be greater than 0
在PHP8中對此進行了優化:
strlen([]); // TypeError: strlen(): Argument #1 ($str) must be of type string, array given
array_chunk([], -1); // ValueError: array_chunk(): Argument #2 ($length) must be greater than 0
現在大多數內部函數在參數驗證失敗時拋出 Error 級異常。
PHP 8 引入了兩個即時編譯引擎。 Tracing JIT 在兩個中更有潛力,它在綜合基準測試中顯示了三倍的性能, 并在某些長時間運行的程序中顯示了 1.5-2 倍的性能改進。 典型的應用性能則和 PHP 7.4 不相上下。
算術/位運算符更嚴格的類型檢測 RFC
Abstract trait 方法的驗證 RFC
確保魔術方法簽名正確 RFC
PHP 引擎 warning 警告的重新分類 RFC
不兼容的方法簽名導致 Fatal 錯誤 RFC
操作符 @ 不再抑制 fatal 錯誤。
私有方法繼承 RFC
Mixed 類型 RFC
Static 返回類型 RFC
內部函數的類型 Email thread
擴展 Curl、 Gd、 Sockets、 OpenSSL、 XMLWriter、 XML 以 Opaque 對象替換 resource。
允許參數列表中的末尾逗號 RFC、 閉包 use 列表中的末尾逗號 RFC
無變量捕獲的 catch RFC
變量語法的調整 RFC
Namespace 名稱作為單個 token RFC
現在 throw 是一個表達式 RFC
允許對象的 ::class RFC
Weak Map 類
Stringable 接口
str_contains()、 str_starts_with()、 str_ends_with()
fdiv()
get_debug_type()
get_resource_id()
token_get_all() 對象實現
New DOM Traversal and Manipulation APIs
PHP 8是一個新的大版本,很多代碼的寫法都進行了優化,如果要將項目升級為PHP8,代碼被破壞的可能性更高,不過如果你使用的是最新版本的PHP,升級起來就會比較輕松,因為其中的大多數重大更改在PHP7中已經棄用。
關于“PHP8新特性有哪些及怎么使用”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識,可以關注億速云行業資訊頻道,小編每天都會為大家更新不同的知識點。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。