C++中唯一三元運算符?:實例詳解
C++三元運算符?:
C++有3種運算符:算數(shù)運算符、關(guān)系運算符和邏輯運算符。
運算符在計算機(jī)中的執(zhí)行順序
運算符用來構(gòu)成表達(dá)式并指示計算機(jī)執(zhí)行計算,其基本特性就是優(yōu)先級和結(jié)合律。在沒有使用小括號確定一個復(fù)合表達(dá)式中個運算符的計算順序的情況下,編譯器將使用它們的優(yōu)先級和結(jié)合律老確定計算順序,優(yōu)先級越高的運算符越先運算。
如果代碼行中的運算符比較多,用括號確定表達(dá)式中每一個子表達(dá)式的計算順序,避免使用默認(rèn)優(yōu)先級。
C++中唯一的三元運算符
條件運算符“?:“,其語法為:
// 條件表達(dá)式 ? 表達(dá)式1 : 表達(dá)式2; bool b_show = true; int state = b_show ? 0 : 1; // state = 0;
語義:如果“條件表達(dá)式”為true,則整個表達(dá)式的值就是表達(dá)式1,忽略表達(dá)式2;如果“條件表達(dá)式”為false,則整個表達(dá)式的值就是表達(dá)式2,忽略表達(dá)式1。等價于以下if/else語句
Result result; if (條件表達(dá)式) { result = 表達(dá)式1; } else { result = 表達(dá)式2; }
C++三元運算符的一個有意思的地方
同學(xué)群里面討論的,感覺很有意思,就記錄下來了。
問題如下:
代碼一
cout << (1 > 2 ? 1 : "1") << endl;
代碼二
cout << (1 > 2 ? 0 : "1") << endl;
代碼三
cout << (1 > 2 ? "hello" : "hi") << endl;
運行結(jié)果是代碼一出錯 error C2446: “:”: 沒有從“const char *”到“int”的轉(zhuǎn)換,代碼二和三沒有任何問題。
這里再回顧下三元運算符的用法。
val = exp1 ? exp2 : exp3
exp1為真則val = exp2否則val = exp3。
因此不論什么時候都會涉及到一個val后等號的類型轉(zhuǎn)換。
答案其實很簡單,0可以視作null,因此默認(rèn)代碼二中cout輸出類型是char *,代碼三中亦是如此,而代碼一中則會出現(xiàn)兩種不同的類型,無法順利進(jìn)行類型轉(zhuǎn)換。
此外如果是代碼二的條件為假的情況,則連endl也不會輸出,這個就不知道怎么回事了。
代碼四:
cout << (1 > 2 ? 0 : '1') << endl;
會正確的轉(zhuǎn)換成int類型。
結(jié)論:
編譯器在編譯的時候就根據(jù)exp2和exp3確定了val的接收類型,再傳給cout。
這里一個不規(guī)范的0的寫法導(dǎo)致了代碼二的正常執(zhí)行。
總結(jié)
到此這篇關(guān)于C++中唯一三元運算符?:的文章就介紹到這了,更多相關(guān)C++三元運算符?:內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
c++網(wǎng)絡(luò)編程下Linux的epoll技術(shù)和Windows下的IOCP模型
c++ 網(wǎng)絡(luò)編程LINUX-epoll/windows-IOCP下socket opoll函數(shù)用法 優(yōu)于select方法的epoll 以及windows下IOCP 解決多進(jìn)程服務(wù)端創(chuàng)建進(jìn)程資源浪費問題,感興趣的小伙伴一起來學(xué)習(xí)吧2021-08-08