問(wèn)結(jié)果是多少。
第一反應(yīng):-3。不過(guò)結(jié)果似乎不是這樣的,寫(xiě)了個(gè)程序,運(yùn)行了一下,發(fā)現(xiàn)是:4294967293。很詭異的一個(gè)數(shù)字,怎么也想不明白為什么會(huì)是這么個(gè)奇怪的數(shù)字。但是在我發(fā)現(xiàn)這數(shù)的十六進(jìn)制數(shù)是FFFFFFFD時(shí),我想我已經(jīng)離答案很近了...
這個(gè)涉及到了混合著不同數(shù)據(jù)類型的表達(dá)式中的數(shù)據(jù)類型的轉(zhuǎn)換問(wèn)題。在總結(jié)轉(zhuǎn)換問(wèn)題之前,先說(shuō)明一下各種數(shù)據(jù)類型(只說(shuō)明numeric類型的),下表來(lái)自MSDN:
| Type Name |
Bytes |
Other Names |
Range of Values |
| int |
* |
signed, signed int |
System dependent |
| unsigned int |
* |
unsigned |
System dependent |
| __int8 |
1 |
char, signed char |
–128 to 127 |
| __int16 |
2 |
short, short int, signed short int |
–32,768 to 32,767 |
| __int32 |
4 |
signed, signed int |
–2,147,483,648 to 2,147,483,647 |
| __int64 |
8 |
none |
–9,223,372,036,854,775,808 to 9,223,372,036,854,775,807 |
| char |
1 |
signed char |
–128 to 127 |
| unsigned char |
1 |
none |
0 to 255 |
| short |
2 |
short int, signed short int |
–32,768 to 32,767 |
| unsigned short |
2 |
unsigned short int |
0 to 65,535 |
| long |
4 |
long int, signed long int |
–2,147,483,648 to 2,147,483,647 |
| unsigned long |
4 |
unsigned long int |
0 to 4,294,967,295 |
| enum |
* |
none |
Same as int |
| float |
4 |
none |
3.4E +/- 38 (7 digits) |
| double |
8 |
none |
1.7E +/- 308 (15 digits) |
| long double |
10 |
none |
1.2E +/- 4932 (19 digits) |
對(duì)上表補(bǔ)充說(shuō)明一下:
1)在32位機(jī)上,int型和unsigned int型都是32位的(4個(gè)字節(jié))。
2)enum會(huì)跟據(jù)最大值來(lái)決定類型,一般來(lái)說(shuō)為int型,如果超出int型所能表示的范圍,則用比int型大的最小類型來(lái)表示(unsigned int, long 或者unsigned long)
3)關(guān)于類型的大小。一般用所能表示的數(shù)據(jù)范圍來(lái)比較類型的大小,如char型<unsigned char型<short型...在表達(dá)式中,一般都是由小的類型向大的類型轉(zhuǎn)換(強(qiáng)制類型轉(zhuǎn)換除外)
下面結(jié)合自己查的資料,加上自己不斷地舉各種情況編程,總結(jié)一下關(guān)于類型轉(zhuǎn)換(僅限于算術(shù)表達(dá)式中關(guān)于整數(shù)類型的轉(zhuǎn)換)的一些問(wèn)題(如有缺漏,歡迎補(bǔ)充,感激不盡)
1、所有比int型小的數(shù)據(jù)類型(包括char,signed char,unsigned char,short,signed short,unsigned short)轉(zhuǎn)換為int型。如果轉(zhuǎn)換后的數(shù)據(jù)會(huì)超出int型所能表示的范圍的話,則轉(zhuǎn)換為unsigned int型;
2、bool型轉(zhuǎn)化為int型時(shí),false轉(zhuǎn)化為0,true轉(zhuǎn)換為1;反過(guò)來(lái)所有的整數(shù)類型轉(zhuǎn)化為bool時(shí),0轉(zhuǎn)化為false,其它非零值都轉(zhuǎn)為true;
3、如果表達(dá)式中混有unsigned short和int型時(shí),如果int型數(shù)據(jù)可以表示所有的unsigned short型的話,則將unsigned short類型的數(shù)據(jù)轉(zhuǎn)換為int型,否則,unsigned short類型及int型都轉(zhuǎn)換為unsigned int類型。舉個(gè)例子,在32位機(jī)上,int是32位,范圍–2,147,483,648 to 2,147,483,647,unsigned short是16位,范圍0 to 65,535,這樣int型的足夠表示unsigned short類型的數(shù)據(jù),因此在混有這兩者的運(yùn)算中,unsigned short類型數(shù)據(jù)被轉(zhuǎn)換為int型;
4、unsigned int 與long類型的轉(zhuǎn)換規(guī)律同3,在32位機(jī)上,unsigned int是32位,范圍0 to 4,294,967,295,long是32位,范圍–2,147,483,648 to 2,147,483,647,可見(jiàn)long類型不夠表示所有的unsigned int型,因此在混有unsigned int及l(fā)ong的表達(dá)式中,兩者都被轉(zhuǎn)換為unsigned long;
5、如果表達(dá)式中既有int 又有unsigned int,則所有的int數(shù)據(jù)都被轉(zhuǎn)化為unsigned int類型。
經(jīng)過(guò)這番總結(jié),前面提出的問(wèn)題的答案應(yīng)該就很明顯了吧。在表達(dá)式i*-1中,i是unsigned int型,-1是int型(常量整數(shù)的類型同enum),按第5條可以知道-1必須轉(zhuǎn)換為unsigned int型,即0xffffffff,十進(jìn)制的4294967295,然后再與i相乘,即4294967295*3,如果不考慮溢出的話,結(jié)果是12884901885,十六進(jìn)制0x2FFFFFFFD,由于unsigned int只能表示32位,因此結(jié)果是0xfffffffd,即4294967293。
嗯,大約就是這樣了。你感興趣的話,可以換各種形式去寫(xiě)寫(xiě)程序,看看結(jié)果,很有意思的哦。