字节对齐
2015-07-08 22:55
239 查看
1 字节对齐的原则:每个字段的起始偏移地址必须是该字段的倍数,并且总的大小必须是最大的字段的size的倍数。
字符串数组是按一个个byte来算的。
typedef struct
{
unsigned short id;
unsigned short data_size;
char data[506];
unsigned short verify_code;
} verify_data_t;
所以sizeof(verify_data_t) = 2 + 2 + 506 + 2 = 512
typedef struct
{
char buf_head[6];
char x1[1];
char name[11];
char x2[1];
verify_data_t verify_data;
char x3[1];
char tail[4];
} full_data_t;----538
sizeof(full_data_t) = 6 + 1 + 11 + 1(19) + 1(as next field is unsigned short id 2 bytes, offset should be 2*multi) + 512 + 1 + 4 + 1(total length should be 2*multi) = 538.
2 字节对齐的缘由: 是cpu访问数据的效率问题,决定了字节对齐的必要性。
如果一个整型变量float字节的地址是0x00000004,那ok,读取一次就获取到了。而如果地址是0x00000002,那么就要读取两次
0x00000002-0x00000003(2个字节),然后再去2个字节(0x00000004-0x00000005)。
1 字节对齐的原则:每个字段的起始偏移地址必须是该字段的倍数,并且总的大小必须是最大的字段的size的倍数。
字符串数组是按一个个byte来算的。
typedef struct
{
unsigned short id;
unsigned short data_size;
char data[506];
unsigned short verify_code;
} verify_data_t;
所以sizeof(verify_data_t) = 2 + 2 + 506 + 2 = 512
typedef struct
{
char buf_head[6];
char x1[1];
char name[11];
char x2[1];
verify_data_t verify_data;
char x3[1];
char tail[4];
} full_data_t;----538
sizeof(full_data_t) = 6 + 1 + 11 + 1(19) + 1(as next field is unsigned short id 2 bytes, offset should be 2*multi) + 512 + 1 + 4 + 1(total length should be 2*multi) = 538.
2 字节对齐的缘由: 是cpu访问数据的效率问题,决定了字节对齐的必要性。
如果一个整型变量float字节的地址是0x00000004,那ok,读取一次就获取到了。而如果地址是0x00000002,那么就要读取两次
0x00000002-0x00000003(2个字节),然后再去2个字节(0x00000004-0x00000005)。
相关文章推荐
- 给Magento新增JSON-RPC类型的Api适配器(adapter)
- C++中const的实现机制深入分析
- Linux 安装配置 JDK 8
- 6.1-4
- 黑马程序员java类和对象的关系
- DS8K存储分配空间给主机方案
- jsp (五) <jsp:useBean> scope
- Android系列教程之五:Activity的生命周期
- C++模板源代码的三种组织方式
- 字符流总结--Day21
- 黑马程序员 java模板方法模式
- AWS使用心得:当初我曾错过的那些宝贵经验
- Arduino 2048 游戏
- poj 2002 Squares Hash
- Unknown initial character set index '45' received from serve
- ASP.NET MVC Boilerplate简介
- 被忽视但很实用的那部分SQL
- js遇到这样基础题,看你能不能作对呢
- iOS [UIScreen mainScreen].bounds 获取屏幕大小不对的问题
- Leetcode 122 Best Time to Buy and Sell Stock II 不限次数买卖股票最大收益