字节对齐测试实例

先看理论:

1. 更改C编译器的缺省字节对齐方式

在缺省情况下,C编译器为每一个变量或是数据单元按其自然对界条件分配空间。一般地,可以通过下面的方法来改变缺省的对界条件:
· 使用伪指令#pragma pack (n),C编译器将按照n个字节对齐。
· 使用伪指令#pragma pack (),取消自定义字节对齐方式。

另外,还有如下的一种方式
· __attribute((aligned (n))),让所作用的结构成员对齐在n字节自然边界上。如果结构中有成员的长度大于n,则按照最大成员的长度来对齐
· __attribute__ ((packed)),取消结构在编译过程中的优化对齐,按照实际占用字节数进行对齐。

 

测试源码:

#include <stdio.h>
#include <iostream>
#include <map>

using namespace std;

struct stu
{
	char sex;
	long long ss;	// 8
	short length;	// 2
	int s2;			// 4
	char name[10];
//}__attribute__((aligned(1)));		// 按最大成员的长度来对齐(但不超过N,否则按N对齐;N=4(32位机器)/8(64位机器))
}__attribute__((packed));			// 1字节对齐

void test()
{
	struct stu my_stu;
	cout << sizeof(my_stu) << endl;
	printf("%p, %p, %p, %p, %p\n", &my_stu.sex, &my_stu.ss, &my_stu.length, &my_stu.s2, &my_stu.name);
}

int main()
{
	test();	

	return 0;
}

测试结果与我代码中的注释一致,代码本身也比较简单,就不解释了!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值