【C/C++】基本数据类型的字节大小和数值范围
文章目录
一、int型字长问题
① C/C++规定int字长和机器字长相同;
② 操作系统字长和机器字长未必一致;
③ 编译器根据操作系统字长来定义int字长。
由上面三点可知,在一些没有操作系统的嵌入式计算机系统上,int的长度与处理器字长一致;有操作系统时,操作系统的字长与处理器的字长不一定一致,此时编译器根据操作系统的字长来定义int字长:比如你在64位机器上运行DOS16系统,那么所有for dos16的C/C++编译器中int都是16位的;在64位机器上运行win32系统,那么所有for win32的C/C++编译器中int都是32位的。
二、关于不同系统中基本数据类型所占空间大小问题
C标准中并没有具体给出规定那个基本类型应该是多少字节数,而且这个也与机器、OS、编译器有关,比如同样是在32位的操作系统,VC++的编译器下int类型为占4个字节,而tuborC下则是2个字节。所以short int,int,long int,所占空间的大小都可能随编译器而异。但有几条铁定的原则 (ANSI/ISO制订的)
-
sizeof (short int) <= sizeof (int)
-
sizeof (int) <= sizeof (long int)
-
short int至少应为16位 (2字节)
-
long int至少应为32位
三、常见基本数据类型的字节大小
类型 | 说明 | 16位 (字节) | 32位 (字节) | 64位 (字节) | 备注 |
---|---|---|---|---|---|
char | 字符型 | 1 | 1 | 1 | 固定 |
short int | 短整型 | 2 | 2 | 2 | 固定 |
int | 整型 | 2 | 4 | 4 | 变化 |
* | 指针变量 | 2 | 4 | 8 | 变化 |
long int | 长整型 | 4 | 4 | 8 | 变化 |
long long | 长长整型 | 8 | 8 | 8 | 固定 |
float | 单精度浮点型 | 4 | 4 | 4 | 固定 |
double | 双精度浮点型 | 8 | 8 | 8 | 固定 |
注:指针类型存储是指所指向变量的地址,16位机只需16bit, 32位机只需32 bit, 64位机需要64bit。
除了 * 和 long 随操作系统的变化而变化,其它都是固定不变的(16位操作系统下int是2byte)
bool 1字节; char 1字节; int 4字节; float 4字节; double 8字节; long long 8字节。
四、常见基本数据类型的数值范围
4.1 无符号整型
类型 | 字节数 | unsigned |
---|---|---|
char | 1 | 0 ~ 255 即 0 ~ ( 2 8 − 1 2^8-1 28−1) |
short int | 2 | 0 ~ 65535 即 0 ~ ( 2 16 − 1 2^{16}-1 216−1) |
int | 4 | 0 ~ 4294967295 即 0 ~ ( 2 32 − 1 2^{32}-1 232−1) |
long int | 4 | 0 ~ 4294967295 即 0 ~ ( 2 32 − 1 2^{32}-1 232−1) (10位) |
long long | 8 | 0 ~ 1.844674407371 e 19 e^{19} e19 即 0 ~ ( 2 64 − 1 2^{64}-1 264−1) (19位) |
4.2 有符号整型
类型 | 字节数 | signed |
---|---|---|
char | 1 | -128 ~ 127 即 - 2 7 2^7 27 ~ ( 2 7 − 1 2^7-1 27−1) |
short int | 2 | -32768 ~ 32767 即 - 2 15 2^{15} 215 ~ ( 2 15 − 1 2^{15}-1 215−1) |
int | 4 | -2147483648 ~ 2147483647 即 - 2 31 2^{31} 231 ~ ( 2 31 − 1 2^{31}-1 231−1) |
long int | 4 | -2147483648 ~ 2147483647 即 - 2 31 2^{31} 231 ~ ( 2 31 − 1 2^{31}-1 231−1) (10位) |
long long | 8 | -9.2233720368548 e 18 e^{18} e18 ~ 9.2233720368548 e 18 e^{18} e18 即 - 2 63 2^{63} 263 ~ ( 2 63 − 1 2^{63}-1 263−1) (19位) |
注:在32位操作系统下
4.3 浮点类型
类型 | 字节数 | signed |
---|---|---|
float | 4 | ± 3.4 e 38 \pm3.4e^{38} ±3.4e38 (精确到6位小数) |
double | 8 | ± 1.7 e 308 \pm1.7e^{308} ±1.7e308 (精确到15位小数) |
long double | 12 | ± 1.2 e 4932 \pm1.2e^{4932} ±1.2e4932 (精确到18位小数) |
4.4 无符号整型的极限值符号
类型名称 | 下限 | 上限 |
---|---|---|
unsigned char | 0 | UCHAR_MAX |
unsigned short | 0 | USHRT_MAX |
unsigned int | 0 | UINT_MAX |
unsigned long | 0 | ULONG_MAX |
unsigned long long | 0 | ULLONG_MAX |
4.5 有符号整型的极限值符号
类型名称 | 下限 | 上限 |
---|---|---|
char | CHAR_MIN | CHAR_MAX |
short | SHRT_MIN | SHRT_MAX |
int | INT_MIN | INT_MAX |
long | LONG_MIN | LONG_MAX |
long long | LLONG_MIN | LLONG_MAX |
4.6 浮点类型的极限值符号
类型名称 | 下限 | 上限 |
---|---|---|
float | FLT_MIN | FLT_MAX |
double | DBL_MIN | DBL_MAX |
long double | LDBL_MIN | LDBL_MAX |