C++筆記十五:C++對C的擴展——三目運算符功能增強
三目運算符在C編譯器中的表現:
int main()
{
int a=10;
int b=20;
//三目運算符是一個表達式,表達式不能做左值
(a<b?a:b)=30;
printf("a=%d,b=%d",a,b);
return 0;
}
運行程序我們發現編譯失敗!
看原因我們看到是表達式不能做左值。
這句話怎麽理解呢?
C語言中,表達式的返回值是一個數,表達式的運算結果放在了CPU的寄存器裏面,而不是內存中,不是一個內存地址(後面查筆記有關C和C++的左值、右值)。
也就是說在C語言中,a=10,b=20,執行a<b?a:b 語句,就是【10<20 嗎?是的!好!那就返回a的值吧!】就把數字“10”返回了,接著就是 10=30,將30賦值給10?這是怎麽個意思,就出錯了!
在C++中,表達式返回的是變量的本身,也就是返回的變量a。
在C++中編譯同樣的代碼:
#include<iostream>
using namespace std;
int main()
{
int a=10;
int b=20;
//三目運算符是一個表達式,表達式不能做左值
(a<b?a:b)=30;
printf("a=%d,b=%d",a,b);
system("pause");
return 0;
}
運行結果:
a=30,b=20
請按任意鍵繼續...
那麽在C語言中如何實現同樣的效果呢?
我們想一下,如果想表達式能當左值,就是說三目表達式應該返回一個內存空間!也就是內存的首地址!內存的首地址是什麽呢?就是指針吧。
a<b ? a:b 這個表達式就算完畢之後,我不想讓它返回a的值10,如果我能返回a的地址,然後再給這個地址賦值那就可以了。
我可以這麽寫:(a < b ? &a : &b) = 30,通過這個地址就可以間接修改指針指向的內存空間,也就間接修改了a的值,註意在括號前面再加上星號“ * ”就是修改對應的值了。我們修改後再運行發現跟C++運行是一樣的。
int main()
{
int a=10;
int b=20;
//三目運算符是一個表達式,表達式不能做左值
*(a<b?&a:&b)=30;
printf("a=%d,b=%d",a,b);
return 0;
}
運行結果:
a=30,b=20
Press any key to continue
所以,C++編譯器是幫我們程序員完成了取地址的工作。
結論:
1、 C語言返回變量的值,C++語言返回變量本身;
C語言中的三目運算符返回的是變量值,不能作為左值使用;
C++中的三目運算符可直接返回變量本身,因此可以出現在程序的任何地方。
2、註意:三目運算符可能返回的值中如果有一個是常量值,則不能作為左值使用,如
(a < b ? 1 : b)= 30;
3、C語言如何支持類似C++的特性呢?
當左值的條件:要有內存空間,C++編譯器幫助程序員取了一個地址而已。
長按解鎖
解鎖更多精彩內幕
依法編程
微信:Lightspeed-Tech
技術驅動生活
C++筆記十五:C++對C的擴展——三目運算符功能增強