成人无码视频,亚洲精品久久久久av无码,午夜精品久久久久久毛片,亚洲 中文字幕 日韩 无码

資訊專欄INFORMATION COLUMN

PHP條件運(yùn)算符的“坑”

xiaowugui666 / 3127人閱讀

摘要:今天遇到一個(gè)關(guān)于嵌套使用條件運(yùn)算符的問(wèn)題現(xiàn)象先來(lái)看一段語(yǔ)言代碼的值編譯后運(yùn)行一下的值答案在意料之中,因?yàn)?,所以被賦值給。

今天遇到一個(gè)關(guān)于PHP 嵌套使用條件運(yùn)算符(ternary expressions)的問(wèn)題

現(xiàn)象

先來(lái)看一段C語(yǔ)言代碼(test.c):

#include
int main() {
  int x = 1;
  int shit = x == 1 ? 100 : 
     x == 2 ? 200 : 300;
  printf("shit的值:%d
", shit);
  return 0;
}

編譯后運(yùn)行一下

root$ gcc test.c -o test && ./test
shit的值:100

答案在意料之中,因?yàn)閤==1,所以100被賦值給shit。

但是如果我們用PHP重寫(xiě)一下上文的代碼(test.php):


執(zhí)行一下:

root$ php test.php
shit的值:200

我們發(fā)現(xiàn)返回的結(jié)果不一樣了,這是為什么呢?

排查

首先懷疑可能是PHP中比較運(yùn)算符(==)和條件運(yùn)算符(?:)的優(yōu)先級(jí)問(wèn)題,我們查看一下PHP官方文檔

==的優(yōu)先級(jí)比?:更高(C語(yǔ)言也是這樣),所以

$shit = $x == 1 ? 100 : 
   $x == 2 ? 200 : 300;

等效于

$shit = ($x == 1) ? 100 : 
   ($x == 2) ? 200 : 300;

執(zhí)行一遍也確實(shí)如此,可以排除掉是運(yùn)算符優(yōu)先級(jí)導(dǎo)致問(wèn)題的可能性了。

但是官方文檔里關(guān)于運(yùn)算符結(jié)合方向的舉例說(shuō)明中出現(xiàn)了這么一句話:

這跟上文描述的現(xiàn)象很相似,問(wèn)題應(yīng)該就在這了。一番查閱之后得到以下結(jié)論:

結(jié)論

C語(yǔ)言的條件運(yùn)算符(?:)的結(jié)合方向是從右往左,每次求值都是從最右邊的子表達(dá)式開(kāi)始算起,所以

int x = 1;

int shit = x == 1 ? 100 : 
     x == 2 ? 200 : 300;
//等效于
int shit = x == 1 ? 100 : 
     (x == 2 ? 200 : 300);
//等效于
int shit = x == 1 ? 100 : 
     (300);// 100

PHP的條件運(yùn)算符(?:)的結(jié)合方向是從左往右,每次求值都是從最左邊的子表達(dá)式開(kāi)始算起,所以

$x = 1;
$shit = $x == 1 ? 100 : 
   $x == 2 ? 200 : 300;
//等效于
$shit = ($x == 1 ? 100 : 
   $x == 2) ? 200 : 300;
//等效于
$shit = (100) ? 200 : 300;// 200

介于PHP的條件運(yùn)算符結(jié)合方向,我們無(wú)法像C/C++那樣 通過(guò)嵌套條件運(yùn)算符來(lái)達(dá)到if-elseif-elseif-else表達(dá)式的效果,除非我們?cè)诳亢蟮淖颖磉_(dá)式中加上括號(hào),本例中就可以靠這種方式解決:

$shit = $x == 1 ? 100 : 
   ($x == 2 ? 200 : 300);

但在條件分支較多的情況下,就會(huì)出現(xiàn)代碼可讀性問(wèn)題(堆積括號(hào)):

$shit = $x == 1 ? 100 :
     ($x == 2 ? 200 :
     ($x== 3 ? 300 :
     ...
     ($x == 8 ? 800 : 900)))))));

由于PHP不堆積括號(hào)的寫(xiě)法與C/C++在執(zhí)行結(jié)果上是不一致的,并且只能通過(guò)加括號(hào)改變默認(rèn)的結(jié)合方向 以達(dá)到預(yù)期的結(jié)果,所以PHP文檔里干脆不建議嵌套使用條件運(yùn)算符:

Note:
It is recommended that you avoid "stacking" ternary expressions. PHP"s
behaviour when using more than one ternary operator within a single statement is non-obvious
參考資料

PHP: Ternary Operator - Manual
PHP: Operator Precedence - Manual
php - Ternary operator left associativity - Stack Overflow
Understanding nested PHP ternary operator - Stack Overflow
C 運(yùn)算符優(yōu)先級(jí)- cppreference.com

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://m.hztianpu.com/yun/29059.html

相關(guān)文章

  • Python里那些深不見(jiàn)底

    摘要:是一門(mén)清晰簡(jiǎn)潔的語(yǔ)言,如果你對(duì)一些細(xì)節(jié)不了解的話,就會(huì)掉入到那些深不見(jiàn)底的坑里,下面,我就來(lái)總結(jié)一些里常見(jiàn)的坑。這是個(gè)很常見(jiàn)但很容易被忽略的一個(gè)坑。 Python是一門(mén)清晰簡(jiǎn)潔的語(yǔ)言,如果你對(duì)一些細(xì)節(jié)不了解的話,就會(huì)掉入到那些深不見(jiàn)底的坑里,下面,我就來(lái)總結(jié)一些Python里常見(jiàn)的坑。 列表創(chuàng)建和引用 嵌套列表的創(chuàng)建 使用*號(hào)來(lái)創(chuàng)建一個(gè)嵌套的list: li = [[]] ...

    KaltZK 評(píng)論0 收藏0
  • 前端面試知識(shí)點(diǎn)目錄整理

    摘要:寫(xiě)在前面金三銀四又到了一年一度的跳槽季相信大家都在準(zhǔn)備自己面試筆記我也針對(duì)自己工作中所掌握或了解的一些東西做了一個(gè)目錄總結(jié)方便自己復(fù)習(xí)詳細(xì)內(nèi)容會(huì)在之后一一對(duì)應(yīng)地補(bǔ)充上去有些在我的個(gè)人主頁(yè)筆記中也有相關(guān)記錄這里暫且放一個(gè)我的面試知識(shí)點(diǎn)目錄大家 寫(xiě)在前面: 金三銀四, 又到了一年一度的跳槽季, 相信大家都在準(zhǔn)備自己面試筆記, 我也針對(duì)自己工作中所掌握或了解的一些東西做了一個(gè)目錄總結(jié),方便自...

    xzavier 評(píng)論0 收藏0
  • 前端面試知識(shí)點(diǎn)目錄整理

    摘要:寫(xiě)在前面金三銀四又到了一年一度的跳槽季相信大家都在準(zhǔn)備自己面試筆記我也針對(duì)自己工作中所掌握或了解的一些東西做了一個(gè)目錄總結(jié)方便自己復(fù)習(xí)詳細(xì)內(nèi)容會(huì)在之后一一對(duì)應(yīng)地補(bǔ)充上去有些在我的個(gè)人主頁(yè)筆記中也有相關(guān)記錄這里暫且放一個(gè)我的面試知識(shí)點(diǎn)目錄大家 寫(xiě)在前面: 金三銀四, 又到了一年一度的跳槽季, 相信大家都在準(zhǔn)備自己面試筆記, 我也針對(duì)自己工作中所掌握或了解的一些東西做了一個(gè)目錄總結(jié),方便自...

    enda 評(píng)論0 收藏0
  • 后端知識(shí)點(diǎn)總結(jié)——PHP

    摘要:后端知識(shí)點(diǎn)總結(jié)服務(wù)器服務(wù)器的作用接收客戶端的請(qǐng)求,查找需要的數(shù)據(jù)文件數(shù)據(jù)庫(kù)其它系統(tǒng),發(fā)送回客戶端。注意默認(rèn)情況下,若判定了某個(gè)相等條件則執(zhí)行該條件以及后續(xù)所有條件中的執(zhí)行語(yǔ)句必須配合關(guān)鍵字使用。 后端知識(shí)點(diǎn)總結(jié)——PHP 1.Web服務(wù)器 Web服務(wù)器的作用:接收客戶端(PC/PAD/PHONE)的請(qǐng)求,查找需要的數(shù)據(jù)(文件/數(shù)據(jù)庫(kù)/其它系統(tǒng)),發(fā)送回客戶端。 Web服務(wù)器分為兩種:...

    Astrian 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

閱讀需要支付1元查看
<