结构体的偏移量计算
2016-05-07 20:44
423 查看
#include<iostream>
using namespace std;
#define FIND(struc,e) (size_t)&(((struc*)0)->e)
struct struc
{
int a; //a的偏移量是0
int b[20]; //b的偏移量是4,因为a的偏移量是0,b的偏移量是a的偏移量加上a的类型的大小算出来的,a是int型的,所以a要占4个字节(在64位机子上),b的偏移量是4
double c; //c的偏移量是88,因为b的偏移量是4,而b所占的字节数是80,所以本来c的偏移量应该是84,但是偏移量的大小又该是这个变量类型的整数倍,即应该是c的 //double类型的8的倍数,所以只能是88
char d; //偏移量是96,是88+8
};
int main()
{
cout<<FIND(struc,d)<<endl;//偏移量的大小必须是该类型的倍数
cout<<sizeof(struc)<<endl;//计算结构体的大小看最后一个变量的偏移量为96,它的大小本来是最后一个变量的偏移量加上最后一个变量的大小,即97,但是这个结构体的大 //小必须是8的倍数(因为结构体里面有一个double类型,必须是8的倍数),所以是104
}
结构体的长度必须是最长的数据元素的整数倍
数据对齐的概念就是说数据所在的内存地址必须是该数据长度的整数倍
using namespace std;
#define FIND(struc,e) (size_t)&(((struc*)0)->e)
struct struc
{
int a; //a的偏移量是0
int b[20]; //b的偏移量是4,因为a的偏移量是0,b的偏移量是a的偏移量加上a的类型的大小算出来的,a是int型的,所以a要占4个字节(在64位机子上),b的偏移量是4
double c; //c的偏移量是88,因为b的偏移量是4,而b所占的字节数是80,所以本来c的偏移量应该是84,但是偏移量的大小又该是这个变量类型的整数倍,即应该是c的 //double类型的8的倍数,所以只能是88
char d; //偏移量是96,是88+8
};
int main()
{
cout<<FIND(struc,d)<<endl;//偏移量的大小必须是该类型的倍数
cout<<sizeof(struc)<<endl;//计算结构体的大小看最后一个变量的偏移量为96,它的大小本来是最后一个变量的偏移量加上最后一个变量的大小,即97,但是这个结构体的大 //小必须是8的倍数(因为结构体里面有一个double类型,必须是8的倍数),所以是104
}
结构体的长度必须是最长的数据元素的整数倍
数据对齐的概念就是说数据所在的内存地址必须是该数据长度的整数倍
相关文章推荐
- Web前端性能优化(二)使用内容分发网络
- CodeForces 598B Queries on a String
- CodeForces 598A Tricky Sum
- Contest 2016-5-7 B(HDU 5616)
- 言叶にできない
- CodeForces 599D Spongebob and Squares
- MySQL在有索引列情况下 和 无索引情况下 select *的输出结果顺序
- Android半透明背景
- 小さな手のひら
- ASP.NET中数据库数据导入Excel并打印
- 学习进度条九
- CodeForces 599C Day at the Beach
- HDU A+B类型
- 周记一发
- C++第五次上机实验
- jQuery事件相关方法
- 女性的转变
- Asp.net中Request.Url的各个属性对应的意义介绍
- 构建之法阅读笔记06
- Linux下几种并发服务器的实现模式