前言
一般对于C/C++下int等基本数字类型,主要关注三个维度,长度、取值范围和最大值的宏定义。下面分三个维度说明下。
有三个影响因素:
- 语言规则限制:比如int是变长,long是定长,double还有精度问题等等;
- 操作系统:某几个类型,Windows和Linux在32位和64位操作系统上的取值是不一致;
- 32位和64位系统在Windows下基本数据类型的大小都是一样的。只有指针的大小不一样!32位指针大小为4byte,而64位的指针大小为8byte。
- 而Linux下64位操作系统是long型是64位的。
- 详情请看:C++那些细节--32位64位数据类型的区别和windows和Linux的数据类型对比(有微软的解释)
- 编译器:编译器才是区分32位和64位的关键因素,因为64位操作系统也可以运行32位程序;但64位程序只能在64位操作系统上运行。
目录
1.长度
类型 | 取值范围 | 位数 |
unsigned int | 0~4294967295 | 10位 |
int | 2147483648~2147483647 | 10位 |
unsigned long | 0~4294967295 | 10位 |
long | 2147483648~2147483647 | 10位 |
long long | -9223372036854775808~9223372036854775807 | 19位 |
unsigned long long | 0~1844674407370955161 | 19位 |
__int64 | -9223372036854775808~9223372036854775807 | 19位 |
unsigned __int64 | 0~18446744073709551615 | 20位 |
关于占用字节数,详情在这里:32位与64位下各类型长度对比,已讲的很好,我不再赘述。
注:I表示int类型,L表示long类型,P表示pointer指针类型,32表示32位系统/编译器,64表示64位系统/编译器。
2.取值范围
首选,说一下C/C++下int等基本数字类型的长度和取值范围。
3.最大值的宏定义
C++中, 经常会使用, 某些类型的最大值, 如int的最大整数(INT_MAX), C的函数中, 包含了这些宏定义.
头文件: #include <climits>
维基百科上的相关说明:
4.参考文档:
https://www.runoob.com/cprogramming/c-standard-library-limits-h.html