所謂隱式類型轉換,就是定義的不同類型的數據在運算時,由編譯器自行轉換撐同一數據類型后再進行運算,而完全無需程序員介入的過程
北美托福答案 很多時候在筆試面試時可能被問到這樣一些類似的問題,比如:
1 int a = 0;
2 a = 3.1415926+3;
3 cout<<a<<endl;
4
5 輸出是什么?
當然這是小兒科,很直白的問法,一般都能反應過來,輸出為6,因為在計算時,首先編譯器將3轉換為double類型,然后執行浮點數加法操作,得到6.1415926;又因為變量a為整型,這是無法改變的,所以編譯器只能丟失一部分數據,從而將6賦值給a。
可是有時候就不那么直接了,比如下面這道題,一開始沒看到提示的時候,我就沒想這回事
雅思答案 void fun()
{
unsigned int a = 2013;
int b = -2;
int c = 0;
while (a + b > 0)
{
a = a + b;
c++;
}
printf("%d", c);
}
據說是小米的筆試題,問程序輸出多少?
貌似是1006?哈哈~那就完蛋了~~ :-) 在C++中定義的內置轉換都按照盡可能防止精度丟失,例如,開頭的浮點數和整數的運算,統一轉換為浮點數進行運算;其他的,比如所有比int小的整型,包括char,short,unsighed char和unsigned short,如果該類型的所有可能的值都能包括在int內,他們就會被提升為int類型,否則將被提升為unsigned int類型。
而對于signed和unsigned int類型又有點特殊。表達式中的signed類型將會被轉換為unsigned類型,坑啊!!~這時我們就好理解上面這個題了,a+b的計算結果是一個unsigned int類型,而unsigned int的表示范圍是0~4294967295,所以就看看a+b有不有可能為0就行了,很顯然,a=2013,每次減2,當減到為1時,unisigned int(1-2)就不是-1了,而是4294967295(因為負數是按補碼表示的),因為a的初值是奇數,每次減2,永遠不可能減成0,所以這個函數一直在while循環中執行,無法跳出,所以什么也不能輸出,不信去試吧
托福答案 其實這個題后來一想也還算好吧,敏感的人可能還是能注意到的,我要是考官,要考這個考點,我就在a,b的定義之后插些其他亂七八糟的程序,輸出一些其他的信息,或者夾著別的東西一起考,讓你感覺這里根本就沒考點,讓那個unsigned不那么明顯,前后很遠,你可能就想不起來這回事了~然后就乖乖往陷阱里跳了。是不是略賤?