1 回答
已采納

onemoo
TA貢獻883條經(jīng)驗 獲得超454個贊
這道題考的就是 運算符優(yōu)先級、整型的布爾值表示、&& 運算符的“短路”特性。
(k == a > b) && (t = a != b)? 這個大復合表達式基礎的部分其實是 && 運算符。
你看我之前說 C 標準沒有規(guī)定很多運算符的操作數(shù)的求值順序,但邏輯運算符 && || 就是例外。其左側操作數(shù)肯定會先求值,如果這個值已經(jīng)可以判斷出邏輯表達式的結果了,就不會再求右側操作數(shù)的值了——這就是所謂“短路”特性。
順便說下,邏輯運算符左側操作數(shù)求值之后是個序列點,當然此題不涉及這個知識點。
這題左側操作數(shù)中 a > b 的結果是 false,布爾值 false 在和整型作比較時會隱式轉型為整形值 0。k 不等于 0,所以左側操作數(shù)的結果是 false。 既然 && 的左側操作數(shù)是 false,那么整個 && 表達式肯定也是 false 了,這樣就沒有必要再判斷右操作數(shù)了——這就是“短路”,所以右操作數(shù)根本就不會被求值(也就是根本就不會被執(zhí)行)。
t 的值不會改變,這時你也沒有必要去分析右側的結果了。
- 1 回答
- 0 關注
- 1150 瀏覽
添加回答
舉報
0/150
提交
取消