32 位 PC 和 64 位 PC 数据类型字节大小及对齐

32 位 PC 和 64 位 PC 数据类型字节大小及对齐

刷牛客网C++,总结一下。这里基于主流的VC编译器考虑。

1. 基本数据类型字节大小

int 字节大小:

  • C/C++规定int字长和机器字长相同;
  • 操作系统字长和机器字长未必一致;
  • 编译器根据操作系统字长来定义int字长;

    我们的32位机和64位机为什么都是固定4byte,就有了解释。因为VC编译器,在32位操作系统变为主流后,int 为4字节,64位系统考虑兼容32位系统的设置,int 也为4字节。更进一步可能需要看一下CPU和汇编相关的资料。

Data type32bit PC64bit PCValue Range
bool1 byte1 bytetrue, false
char1 byte1 byte-128~127
unsigned char1 byte1 byte0~255
short int2 byte2 byte-32768~32767
unsigned short2 byte2 byte0~65535
int4 byte4 byte-2147483648~2147483647
unsigned int4 byte4 byte0~4294967295
long4 byte8 byte
unsigned long4 byte8 byte
long long8 byte8 byte 264 − 2 64 ~ 2641 2 64 − 1
float4 byte4 byte范围 2128 − 2 128 ~ 2128 2 128 精度为6~7位有效数字
double8 byte8 byte范围 21024 − 2 1024 ~ 21024 2 1024 精度为15~16位
long double8 byte8 byte范围 21024 − 2 1024 ~ 21024 2 1024 精度为15~16位
pointer *4 byte8 byte

2. 不同数据类型对齐问题

  1. 对于结构体的各个成员,第一个成员的偏移量是0,排列在后面的成员其当前偏移量必须是当前成员类型的整数倍
  2. 结构体内所有数据成员各自内存对齐后,结构体本身还要进行一次内存对齐,保证整个结构体占用内存大小是结构体内最大数据成员的最小整数倍
  3. 如程序中有#pragma pack(n)预编译指令,则所有成员对齐以n字节为准(即偏移量是n的整数倍),不再考虑当前类型以及最大结构体内类型,但是只有当最大数据成员大于n才行

看一个例题:64位机上,一个结构体有三个成员,分别是char、int、short类型,三个成员位于结构体中不同位置时整个结构体的大小可能是哪些值?

// 由第一节可知,最大数据成员是int 4个字节
// char 1byte short 2byte int 4byte
char short int // char x short  | int | = 8   规则1,自身short的整数倍,2/2 = 1
char int short // char x x x | int | short x x | = 12  规则1, int从第4位开始,规则2, 12/4 = 3
short char int // short char x | int | = 8    规则1
short int char // short x x | int | char x x x | = 12 // 规则1 + 规则2
int char short // int | char x short | = 8    规则1
int short char // int | short char x | = 8    规则1
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值