這篇文章主要講解了“怎么使用PHP8.0新特性之Match表達(dá)式”,文中的講解內(nèi)容簡單清晰,易于學(xué)習(xí)與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“怎么使用PHP8.0新特性之Match表達(dá)式”吧!
成都創(chuàng)新互聯(lián)公司是一家專業(yè)提供平昌企業(yè)網(wǎng)站建設(shè),專注與做網(wǎng)站、成都做網(wǎng)站、H5網(wǎng)站設(shè)計、小程序制作等業(yè)務(wù)。10年已為平昌眾多企業(yè)、政府機(jī)構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專業(yè)網(wǎng)站設(shè)計公司優(yōu)惠進(jìn)行中。上個月下旬PHP社區(qū)發(fā)布是PHP8第一個,正式版本也將于今年年底發(fā)布。PHP8帶來來那個兩個最令人激動的特性:JIT和match表達(dá)式。
本文我們要說另一個新引入的語法match表達(dá)式語法,可以說是PHP 8引入的好的功能之一,它使用類似switch的語法。
基本功能
$status = match($request_method) { 'post' => $this->handlePost(), 'get', 'head' => $this->handleGet(), default => throw new \Exception('Unsupported'), };
用switch...case做對比,要實(shí)現(xiàn)上面的功能,代碼要略繁瑣一點(diǎ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)。
表達(dá)式可以返回一個值
在每個分支可以被分配給一個變量。
$name = match(2) { 1 => 'One', 2 => 'Two', };
不必再將返回值分配給其他中變量,匹配的語句返回值可直接從match表達(dá)式中返回。
可匹配多個條件
match表達(dá)式可能包含一個或多個匹配條件,它們的行為類似于塊中的多個級聯(lián)case鍵switch。
match($request_method) { 'post' => $this->handlePost(), 'get', 'head' => $this->handleGet(), };
滿足$request_method === 'get'和$request_method === 'head'兩個條件都會執(zhí)行$this->handleGet()。
每個分支只能包含一個表達(dá)式
與switch可以包含任意數(shù)量的表達(dá)式的塊不同,一條match語句只能包含一個表達(dá)式。
match($name) { 'XXX' => init(); doth(); };
上面的語法錯誤的。=>只能有一個表達(dá)式。
隱含的break
match表達(dá)式的每個匹配分支僅允許一個表達(dá)式,并且無需switch塊一樣的break。
switch ('test') { case 'test': $this->doTest (); case 'send': $this->sendmsg (); }
在switch...caser容易犯的錯誤是忘記了break語句,這會使流程直接進(jìn)入下一分支。在上面的switch塊中,缺少break;語句會使代碼$this->doTest()無法正常執(zhí)行執(zhí)行。
match ('test') { 'test' => $this->doTest (), 'send' => $this->sendmsg (), };
match表達(dá)式無需顯式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表達(dá)式必須符合條件
switch如果沒有匹配case鍵,則block靜默進(jìn)行代碼流。match表達(dá)式?jīng)]有。
在match表達(dá)式中,必須存在與表達(dá)式匹配的條件或default要處理的條件。如果沒有匹配項(xiàng),而且為設(shè)置default分支,match表達(dá)式將會引發(fā)\UnhandledMatchError異常。
$value = 3; match($value) { 1 => 'One', 2 => 'Two', };
上面的代碼執(zhí)行時候會拋出錯誤:
Fatal error: Uncaught UnhandledMatchError in ...
match\UnhandledMatchError如果表達(dá)式中沒有匹配項(xiàng),則表達(dá)式將引發(fā)異常。
\UnhandledMatchError是PHP 8中的新異常類,它擴(kuò)展了\Error。有關(guān)所有PHP核心異常類的完整層次結(jié)構(gòu)。
該類可以很容易地擴(kuò)展:
class UnhandledMatchError extends \Error {}
對非強(qiáng)制類型的嚴(yán)格匹配
match表達(dá)式中最重要的設(shè)計選擇之一是它對非強(qiáng)制類型的匹配。
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表達(dá)式中,所有匹配的分支都經(jīng)過嚴(yán)格的比較(===)匹配。
在上面的代碼段中,每個單獨(dú)的分支都將匹配其值和類型。
匹配任意表達(dá)式
match 表達(dá)式允許給定值與表達(dá)式匹配。
match($httpst){ 404 => 'Page not found', Response::REDIRECT => 'Redirect', $client->getCode() => 'Client Error', $response->getCode() => 'Response Error', default => 'Unknown error' };
表達(dá)式將按照其排列順序進(jìn)行求值。
match表達(dá)式將嘗試$httpst按以下順序進(jìn)行匹配:
1. $httpst === 404
2. $httpst === Response::REDIRECT
3. $httpst === $client->getCode()
4. $httpst === $response->getCode()
5. default
如果找到正匹配,則將不會對其他分支進(jìn)行嘗試,直接返回。
match VS switch
向后兼容性影響
match表達(dá)式是PHP 8中的新語法。使用match表達(dá)式的代碼在較舊的PHP版本中將不起作用。
感謝各位的閱讀,以上就是“怎么使用PHP8.0新特性之Match表達(dá)式”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對怎么使用PHP8.0新特性之Match表達(dá)式這一問題有了更深刻的體會,具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是創(chuàng)新互聯(lián)網(wǎng)站建設(shè)公司,,小編將為大家推送更多相關(guān)知識點(diǎn)的文章,歡迎關(guān)注!
本文標(biāo)題:怎么使用PHP8.0新特性之Match表達(dá)式-創(chuàng)新互聯(lián)
轉(zhuǎn)載注明:http://jinyejixie.com/article26/ccepjg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站維護(hù)、外貿(mào)建站、網(wǎng)站營銷、標(biāo)簽優(yōu)化、網(wǎng)站收錄、電子商務(wù)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容