(一)32位平台:
分为有符号型与无符号型。
有符号型:
short在内存中占两个字节,范围为-2^15~(2^15-1)
int在内存中占四个字节,范围为-2^31~(2^31-1)
long在内存中占四个字节,范围为-2^31~2^31-1
无符号型:最高位不表示符号位
unsignedshort在内存中占两个字节,范围为0~2^16-1
unsignedint在内存中占四个字节,范围为0~2^32-1
unsignedlong在内存中占四个字节,范围为0~2^32-1
实型变量:
分单精度float和双精度double两种形式:
float:占四个字节,提供7~8位有效数字。
double:占八个字节,提供15~16位有效数字。
(二)16位平台:
1)整型(基本型):类型说明符为int,在内存中占2个字节。
2)短整型:类型说明符为shortint或short。所占字节和取值范围均与整型(基本型)相同。
3)长整型:类型说明符为longint或long,在内存中占4个字节。
无符号型:类型说明符为unsigned。
无符号型又可与上述三种类型匹配而构成:
各种无符号类型量所占的内存空间字节数与相应的有符号类型量相同。但由于省去了符号位,故不能表示负数。
实型变量:
分为单精度(float型)、双精度(double型)和长双精度(longdouble型)三类。
单精度型占4个字节(32位)内存空间,其数值范围为3.4E-38~3.4E+38,只能提供七位有效数字。
双精度型占8个字节(64位)内存空间,其数值范围为1.7E-308~1.7E+308,可提供16位有效数字。
长双精度型16个字节(128位)内存空间,可提供18-19位有效数字。
和机器字长及编译器有关系:
所以,int,longint,shortint的宽度都可能随编译器而异。但有几条铁定的原则(ANSI/ISO制订的):
1sizeof(shortint)<=sizeof(int)
2sizeof(int)<=sizeof(longint)
3shortint至少应为16位(2字节)
4longint至少应为32位。
unsigned是无符号的意思。
更详细学习资料的在我的头条文章仔细的看下,只是粗略的概述了一遍,当然更详细具体的可以自己去找资料,当然也可以加我的群哈368282579,可以交流的,群内也有针对0基础的新手资料,项目资源也是很丰富的,希望对各位有所帮助哈
例如:
16位编译器
char:1个字节
char*(即指针变量):2个字节
shortint:2个字节
int:2个字节
unsignedint:2个字节
float:4个字节
double:8个字节
long:4个字节
longlong:8个字节
unsignedlong:4个字节
32位编译器
(看这里就行了,与16位机,64位机比较,粗体type为不同的,其余的都是相同)
char:1个字节
char*(即指针变量):4个字节(32位的寻址空间是2^32,即32个bit,也就是4个字节。同理64位编译器)(16位机,32位机,64位机各不相同)
shortint:2个字节
int:4个字节(16位机是2B,32位&64位是4B)
unsignedint:4个字节(16位机是2B,32位&64位是4B)
float:4个字节
double:8个字节
long:4个字节(16位&32位是4B,64位是8B)
longlong:8个字节
unsignedlong:4个字节(16&32位是4B,64位是8B)
64位编译器
char:1个字节
char*(即指针变量):8个字节
shortint:2个字节
int:4个字节
unsignedint:4个字节
float:4个字节
double:8个字节
long:8个字节
longlong:8个字节
unsignedlong:8个字节
可以加我的群哈368282579,群内也有针对0基础的新手资料,项目资源
显示全部
收起
最新更新 | 文章排行 | 滇ICP备2023006777号 | 网站地图