C++中唯一三元運算符?:實例詳解
C++三元運算符?:
C++有3種運算符:算數運算符、關系運算符和邏輯運算符。
運算符在計算機中的執行順序
運算符用來構成表達式並指示計算機執行計算,其基本特性就是優先級和結合律。在沒有使用小括號確定一個復合表達式中個運算符的計算順序的情況下,編譯器將使用它們的優先級和結合律老確定計算順序,優先級越高的運算符越先運算。
如果代碼行中的運算符比較多,用括號確定表達式中每一個子表達式的計算順序,避免使用默認優先級。
C++中唯一的三元運算符
條件運算符“?:“,其語法為:
// 條件表達式 ? 表達式1 : 表達式2; bool b_show = true; int state = b_show ? 0 : 1; // state = 0;
語義:如果“條件表達式”為true,則整個表達式的值就是表達式1,忽略表達式2;如果“條件表達式”為false,則整個表達式的值就是表達式2,忽略表達式1。等價於以下if/else語句
Result result; if (條件表達式) { result = 表達式1; } else { result = 表達式2; }
C++三元運算符的一個有意思的地方
同學群裡面討論的,感覺很有意思,就記錄下來瞭。
問題如下:
代碼一
cout << (1 > 2 ? 1 : "1") << endl;
代碼二
cout << (1 > 2 ? 0 : "1") << endl;
代碼三
cout << (1 > 2 ? "hello" : "hi") << endl;
運行結果是代碼一出錯 error C2446: “:”: 沒有從“const char *”到“int”的轉換,代碼二和三沒有任何問題。
這裡再回顧下三元運算符的用法。
val = exp1 ? exp2 : exp3
exp1為真則val = exp2否則val = exp3。
因此不論什麼時候都會涉及到一個val後等號的類型轉換。
答案其實很簡單,0可以視作null,因此默認代碼二中cout輸出類型是char *,代碼三中亦是如此,而代碼一中則會出現兩種不同的類型,無法順利進行類型轉換。
此外如果是代碼二的條件為假的情況,則連endl也不會輸出,這個就不知道怎麼回事瞭。
代碼四:
cout << (1 > 2 ? 0 : '1') << endl;
會正確的轉換成int類型。
結論:
編譯器在編譯的時候就根據exp2和exp3確定瞭val的接收類型,再傳給cout。
這裡一個不規范的0的寫法導致瞭代碼二的正常執行。
總結
到此這篇關於C++中唯一三元運算符?:的文章就介紹到這瞭,更多相關C++三元運算符?:內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!