一、结构体大小计算方法
结构体的大小,一定是结构体内所占字节最大的变量的整数倍。
内存对齐:例如,对于4字节对齐的结构体,其对齐数为4,数据成员的偏移量必须是4的整数倍。对于4字节的数据必须放在4的整数倍位置,第一个4字节数据放在第0位,第二个4字节数据放在第4位,第三个4字节的数据放在第8位,以此类推......
二、存储方式
大端模式,是指数据的高字节保存在内存的低地址中,而数据的低字节保存在内存的高地址中,存储模式类似把数据当作字符串顺序处理。
小端模式,是指数据的高字节保存在内存的高地址中,而数据的低字节保存在内存的低地址中,存储模式将地址的高低和数据位权有效地结合起来。
三、实例
#include <stdio.h>
struct test{
char a;
short b;
int c;
short d;
char e;
}t1;
/* #pragma pack(n)用法 */
/* 如果 n 大于结构体内最大数据类型变量的所占字节,则对齐方式采用结构体内最大数据类型变量的所占字节数量。*/
/* n 等于 1 时,不做任何对齐,直接存数据。*/
#pragma pack(2) //自定义对齐方式为2字节。
struct test_02{
char c;
short a;
int b;
}t2;
int main(void)
{
t1.a = 0x11;
t1.b = 0x2233;
t1.c = 0x44556677;
t1.d = 0x8899;
t1.e = 0x12;
t2.a = 0x11;
t2.b = 0x22;
t2.c = 0x33;
int size_01 = sizeof(t1);
int size_02 = sizeof(t2);
printf("t1 size = %d B(字节)\n",size_01);
printf("t2 size = %d B(字节)\n",size_02);
unsigned char* p = (unsigned char*)&t1;
int i = 0;
for(i = 0; i < size_01; i++)
{
printf("[%x] ", *p);
p++;
}
return 0;
}
输出结果