主頁 > 知識庫 > PHP8.0新功能之Match表達式的使用

PHP8.0新功能之Match表達式的使用

熱門標簽:菏澤語音外呼系統(tǒng)運營商 臨沂crm外呼系統(tǒng)平臺 如何在世界地圖標注 地圖標注符號樣式有 電子地圖標注怎么修改 廈門400電話辦理選易號網(wǎng) 天客通地圖標注 公司外呼系統(tǒng)中心 梧州市機器人外呼系統(tǒng)怎么樣

上個月下旬PHP社區(qū)發(fā)布是PHP8第一個,正式版本也將于今年年底發(fā)布。PHP8帶來來那個兩個最令人激動的特性:JIT和match表達式。

本文我們要說另一個新引入的語法match表達式語法,可以說是PHP 8引入的最好的功能之一,它使用類似switch的語法。

基本功能

$status = match($request_method) { 
'post' => $this->handlePost(), 
'get', 'head' => $this->handleGet(), 
default => throw new \Exception('Unsupported'), 
}; 

用switch...case做對比,要實現(xiàn)上面的功能,代碼要略繁瑣一點:

switch ($request_method) { 
case 'post': 
$status = $this->handlePost(); 
break; 
case 'get': 
case 'head': 
$status = $this->handleGet(); 
break; 
default: 
throw new \Exception('Unsupported'); 
}; 

相比switch, match會直接返回值,無需中間變量(比如上例中的$status)。

表達式可以返回一個值

在每個分支可以被分配給一個變量。

$name = match(2) { 
1 => 'One', 
2 => 'Two', 
}; 

不必再將返回值分配給其他中變量,匹配的語句返回值可直接從match表達式中返回。

可匹配多個條件

match表達式可能包含一個或多個匹配條件,它們的行為類似于塊中的多個級聯(lián)case鍵switch。

match($request_method) { 
'post' => $this->handlePost(), 
'get', 'head' => $this->handleGet(), 
}; 

滿足$request_method === 'get'和$request_method === 'head'兩個條件都會執(zhí)行$this->handleGet()。

每個分支只能包含一個表達式

與switch可以包含任意數(shù)量的表達式的塊不同,一條match語句只能包含一個表達式。

match($name) { 
'XXX' => 
init(); 
doth(); 
}; 

上面的語法錯誤的。=>只能有一個表達式。

隱含的break

match表達式的每個匹配分支僅允許一個表達式,并且無需switch塊一樣的break。

switch ('test') { 
case 'test': 
$this->doTest (); 
case 'send': 
$this->sendmsg (); 
} 

在switch...caser容易犯的錯誤是忘記了break語句,這會使流程直接進入下一分支。在上面的switch塊中,缺少break;語句會使代碼$this->doTest()無法正常執(zhí)行執(zhí)行。

match ('test') { 
'test' => $this->doTest (), 
'send' => $this->sendmsg (), 
}; 

match表達式無需顯式break語句即可工作。它只執(zhí)行一個match分支,并立即返回該值。

default分支

match語句支持一個default分支,該分支工作原理與switch...case塊中的default情況類似。如果沒有其他條件相匹配,將執(zhí)行default match分支。

match ('DEF') { 
'aaa' => ..., 
'bbb' => ..., 
default => echo 'NO matching: ' . $name, 
}; 
 
// "NO matchin: DEFF" 

match表達式必須符合條件

switch如果沒有匹配case鍵,則block靜默進行代碼流。match表達式?jīng)]有。

在match表達式中,必須存在與表達式匹配的條件或default要處理的條件。如果沒有匹配項,而且為設置default分支,match表達式將會引發(fā)\UnhandledMatchError異常。

$value = 3; 
match($value) { 
1 => 'One', 
2 => 'Two', 
}; 

上面的代碼執(zhí)行時候會拋出錯誤:

Fatal error: Uncaught UnhandledMatchError in ... 

match\UnhandledMatchError如果表達式中沒有匹配項,則表達式將引發(fā)異常。

\UnhandledMatchError是PHP 8中的新異常類,它擴展了\Error。有關所有PHP核心異常類的完整層次結構。

該類可以很容易地擴展:

class UnhandledMatchError extends \Error {} 

對非強制類型的嚴格匹配

match表達式中最重要的設計選擇之一是它對非強制類型的匹配。

function read(mixed $key): string { 
return match ($key) { 
1 => 'Integer 1', 
'1' => 'String 1', 
true => 'Bool true', 
[] => 'Empty array', 
[1] => 'Array [1]', 
}; 
} 
 
read(1); // "Integer 1" 
read('1'); // "String 1" 

在典型的switch塊中,其大小寫是松散匹配的,即與==。在match表達式中,所有匹配的分支都經(jīng)過嚴格的比較(===)匹配。

在上面的代碼段中,每個單獨的分支都將匹配其值和類型。

匹配任意表達式

match 表達式允許給定值與表達式匹配。

match($httpst){ 
404 => 'Page not found', 
Response::REDIRECT => 'Redirect', 
$client->getCode() => 'Client Error', 
$response->getCode() => 'Response Error', 
default => 'Unknown error' 
}; 

表達式將按照其排列順序進行求值。

match表達式將嘗試$httpst按以下順序進行匹配:

1. $httpst === 404
2. $httpst === Response::REDIRECT
3. $httpst === $client->getCode()
4. $httpst === $response->getCode()
5. default

如果找到正匹配,則將不會對其他分支進行嘗試,直接返回。

match VS switch

向后兼容性影響

match表達式是PHP 8中的新語法。使用match表達式的代碼在較舊的PHP版本中將不起作用。

到此這篇關于PHP8.0新功能之Match表達式的使用的文章就介紹到這了,更多相關PHP8.0 Match表達式內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • PHP preg_match實現(xiàn)正則表達式匹配功能【輸出是否匹配及匹配值】
  • PHP preg match正則表達式函數(shù)的操作實例
  • PHP函數(shù)preg_match_all正則表達式的基本使用詳細解析
  • PHP 正則表達式之正則處理函數(shù)小結(preg_match,preg_match_all,preg_replace,preg_split)

標簽:郴州 白城 瀘州 黃石 綿陽 貴陽 迪慶 雞西

巨人網(wǎng)絡通訊聲明:本文標題《PHP8.0新功能之Match表達式的使用》,本文關鍵詞  PHP8.0,新功能,之,Match,表達式,;如發(fā)現(xiàn)本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《PHP8.0新功能之Match表達式的使用》相關的同類信息!
  • 本頁收集關于PHP8.0新功能之Match表達式的使用的相關信息資訊供網(wǎng)民參考!
  • 推薦文章