問結(jié)果是多少。
第一反應(yīng):-3。不過結(jié)果似乎不是這樣的,寫了個程序,運行了一下,發(fā)現(xiàn)是:4294967293。很詭異的一個數(shù)字,怎么也想不明白為什么會是這么個奇怪的數(shù)字。但是在我發(fā)現(xiàn)這數(shù)的十六進(jìn)制數(shù)是FFFFFFFD時,我想我已經(jīng)離答案很近了...
這個涉及到了混合著不同數(shù)據(jù)類型的表達(dá)式中的數(shù)據(jù)類型的轉(zhuǎn)換問題。在總結(jié)轉(zhuǎn)換問題之前,先說明一下各種數(shù)據(jù)類型(只說明numeric類型的),下表來自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) |
對上表補(bǔ)充說明一下:
1)在32位機(jī)上,int型和unsigned int型都是32位的(4個字節(jié))。
2)enum會跟據(jù)最大值來決定類型,一般來說為int型,如果超出int型所能表示的范圍,則用比int型大的最小類型來表示(unsigned int, long 或者unsigned long)
3)關(guān)于類型的大小。一般用所能表示的數(shù)據(jù)范圍來比較類型的大小,如char型<unsigned char型<short型...在表達(dá)式中,一般都是由小的類型向大的類型轉(zhuǎn)換(強(qiáng)制類型轉(zhuǎn)換除外)
下面結(jié)合自己查的資料,加上自己不斷地舉各種情況編程,總結(jié)一下關(guān)于類型轉(zhuǎn)換(僅限于算術(shù)表達(dá)式中關(guān)于整數(shù)類型的轉(zhuǎn)換)的一些問題(如有缺漏,歡迎補(bǔ)充,感激不盡)
1、所有比int型小的數(shù)據(jù)類型(包括char,signed char,unsigned char,short,signed short,unsigned short)轉(zhuǎn)換為int型。如果轉(zhuǎn)換后的數(shù)據(jù)會超出int型所能表示的范圍的話,則轉(zhuǎn)換為unsigned int型;
2、bool型轉(zhuǎn)化為int型時,false轉(zhuǎn)化為0,true轉(zhuǎn)換為1;反過來所有的整數(shù)類型轉(zhuǎn)化為bool時,0轉(zhuǎn)化為false,其它非零值都轉(zhuǎn)為true;
3、如果表達(dá)式中混有unsigned short和int型時,如果int型數(shù)據(jù)可以表示所有的unsigned short型的話,則將unsigned short類型的數(shù)據(jù)轉(zhuǎn)換為int型,否則,unsigned short類型及int型都轉(zhuǎn)換為unsigned int類型。舉個例子,在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ù),因此在混有這兩者的運算中,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,可見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)過這番總結(jié),前面提出的問題的答案應(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。
嗯,大約就是這樣了。你感興趣的話,可以換各種形式去寫寫程序,看看結(jié)果,很有意思的哦。