1、有一个如下的结构体:
struct A{
long a1;
short a2;
int a3;
int *a4;
};
请问在64位编译器下用sizeof(struct A)计算出的大小是多少?(24)
8 + 2 + 4 + 8 = 22, 对齐为8的倍数:24
32位编译器:32位系统下指针占用4字节
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位编译器:64位系统下指针占用8字节
char :1个字节
char*(即指针变量): 8个字节
short int : 2个字节
int: 4个字节
unsigned int : 4个字节
float: 4个字节
double: 8个字节
long: 8个字节
long long: 8个字节
unsigned long: 8个字节
2、再看下例:32位编译器
#include <iostream>
#include<string.h>
#include<stdlib.h>
using namespace std;
/*结构体的内存空间:
a. 当结构体内元素的长度都小于处理器的位数时:
以结构体内最长的数据元素为对齐单位,即结构体的长度一定是最长数据元素的整数倍。
b. 当结构体内存在长度大于处理器位数的元素时,以处理器的位数为对齐单位,但是结
构体内类型相同的连续元素将在连续的空间内。*/
/*结构体A中3个short类型,各自以2字节对齐,结构体对齐参数按默认的8字节对齐
则a1,a2,a3都取2字节对齐,sizeof(A)=6!!!!,也是2的整数倍。*/
struct
{
short a1;//2
short a2;//2
short a3;//2
}A;
struct //sizeof(B)=8 !!!!
{
long a1;//4
short a2;//2
}B;