内存字节对齐
来源:互联网 发布:网站源码授权程序 编辑:程序博客网 时间:2024/06/08 02:35
原文点这里
要点:
1. 数据成员对齐规则:结构(struct)(或联合(union))的数据成员,第一个数据成员放在offset为0的地方,以后每个数据成员存储的起始位置要从该成员大小或者成员的子成员大小(只要该成员有子成员,比如说是数组,结构体等)的整数倍开始(比如int在32位机为4字节,则要从4的整数倍地址开始存储。
2. 结构体作为成员:如果一个结构里有某些结构体成员,则结构体成员要从其内部最大元素大小的整数倍地址开始存储(struct a里存有struct b,b里有char,int ,double等元素,那b应该从8的整数倍开始存储)。
3. 收尾工作:结构体的总大小(也就是sizeof的结果)必须是其内部最大成员的整数倍,不足的要补齐。
示例:
typedef struct bb{ int id; // [0]...[3] double weight; // [8]...[15] 原则1 float height; // [16]...[19] 总长要为8的整数倍,补齐[20]...[23] 原则3}BB;typedef struct aa{ char name[2]; // [0]...[1] int id; // [4]...[7] 原则1 double score; // [8]...[15] short grade; // [16]...[17] BB b; // [24]...[47] 原则2}AA;int main(){ AA a; cout<<sizeof(a)<<" "<<sizeof(BB)<<endl; // 在#pragma pack(8)的情况下输出:48 24 return 0;}
0 0
- 内存字节对齐
- 内存字节对齐
- 内存字节对齐
- 内存字节对齐详解
- 内存中字节对齐
- c++ 内存 字节对齐
- 内存字节对齐详解
- 内存字节对齐
- 内存字节对齐
- 内存字节对齐
- 关于字节内存对齐
- 内存字节对齐总结
- 内存字节对齐总结
- 内存字节对齐
- 内存字节对齐
- 关于内存字节对齐
- 内存字节对齐
- 内存字节对齐
- 游戏碰撞之OBB算法实现(java代码实现)
- Stanford机器学习---第八讲. 支持向量机SVM
- Handler Runnable和Thread之间的区别和联系
- CF # 296 C Glass Carving (并查集 或者 multiset)
- iOS应用安全Part2:获取iOS应用的类信息
- 内存字节对齐
- svn: Unable to connect to a repository at URL eclipse
- Android验证手机号码的正则表达式
- Stanford机器学习---第九讲. 聚类
- Cocos2d-x v2.2.3 IOS,Android “一键式”播放视频
- 如何将android项目生成apk ?
- MyBatis 3 自动生成 主键 针对不同的数据库(oracle/sqlserver/mysql)
- selenium + Python 下拉框选择
- 解决H2数据库的webAllowOthers禁用