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