關於這個基本的問題,很早以前就很清楚了,C標準中並沒有具體給出規定那個基本類型應該是多少字節數,而且這個也與機器、OS、編譯器有關,比如同樣是在32bits的操作系統系,VC++的編譯器下int類型爲佔4個字節;而tuborC下則是2個字節。
所以int,long int,short int的寬度都可能隨編譯器而異。但有幾條鐵定的原則(ANSI/ISO制訂的):
-
sizeof(short int)<=sizeof(int)
-
sizeof(int)<=sizeof(long int)
-
short int至少應爲16位(2字節)
-
long int至少應爲32位。
下面給出不同位數編譯器下的基本數據類型所佔的字節數:
16位編譯器
char :1個字節
char*(即指針變量): 2個字節
short int : 2個字節
int: 2個字節
unsigned int : 2個字節
float: 4個字節
double: 8個字節
long: 4個字節
long long: 8個字節
unsigned long: 4個字節
32位編譯器
char :1個字節
char*(即指針變量): 4個字節(32位的尋址空間是2^32, 即32個bit,也就是4個字節。同理64位編譯器)
short int : 2個字節
int: 4個字節
unsigned int : 4個字節
float: 4個字節
double: 8個字節
long: 4個字節
long long: 8個字節
unsigned long: 4個字節
64位編譯器
char*(即指針變量): 8個字節
short int : 2個字節
int: 4個字節
unsigned int : 4個字節
float: 4個字節
double: 8個字節
long: 8個字節
long long: 8個字節
unsigned long: 8個字節
機器字長:是指計算機進行一次整數運算所能處理的二進制數據的位數(整數運算即定點整數運算)。機器字長也就是運算器進行定點數運算的字長,通常也是CPU內部數據通路的寬度。現在一般爲32位即4個字節,也有64位和16位的。
算術類型的存儲空間按照機器而定。一般,short類型爲半個機器字長,int爲一個機器字長,long爲1或2個機器字長,float爲一個機器字長,double爲兩個字,long double用3或4個字長。C++標準規定的是每個算術類型的最小存儲空間,但其並不阻止編譯器用更大的存儲空間。如果要保證移植性,儘量用__int16 __int32 __int64吧,或者自己typedef int INT32一下。
數據類型名稱 | 字節數 | 別名 | 取值範圍 |
int | * | signed,signed int | 由操作系統決定,即與操作系統的"字長"有關 |
unsigned int | * | unsigned | 由操作系統決定,即與操作系統的"字長"有關 |
__int8 | 1 | char,signed char | –128 到 127 |
__int16 | 2 | short,short int,signed short int | –32,768 到 32,767 |
__int32 | 4 | signed,signed int | –2,147,483,648 到 2,147,483,647 |
__int64 | 8 | 無 | –9,223,372,036,854,775,808 到 9,223,372,036,854,775,807 |
bool | 1 | 無 | false 或 true |
char | 1 | signed char | –128 到 127 |
unsigned char | 1 | 無 | 0 到 255 |
short | 2 | short int,signed short int | –32,768 到 32,767 |
unsigned short | 2 | unsigned short int | 0 到 65,535 |
long | 4 | long int,signed long int | –2,147,483,648 到 2,147,483,647 |
long long | 8 | none (but equivalent to __int64) | –9,223,372,036,854,775,808 到 9,223,372,036,854,775,807 |
unsigned long | 4 | unsigned long int | 0 到 4,294,967,295 |
enum | * | 無 | 由操作系統決定,即與操作系統的"字長"有關 |
float | 4 | 無 | 3.4E +/- 38 (7 digits) |
double | 8 | 無 | 1.7E +/- 308 (15 digits) |
long double | 8 | 無 | 1.7E +/- 308 (15 digits) |
wchar_t | 2 | __wchar_t | 0 到 65,535 |
(P:指針的大小爲定值4個字節)