首页 > 代码库 > 内存对齐方式
内存对齐方式
示例1:
<span style="font-size:18px;">#include <iostream> using namespace std; struct Node1{ bool m1; int m2; bool m3; double m4; bool m5; }; // struct Node2{ // char m1; // char m2; // int m3; // }; int main() { cout << sizeof(Node1) << endl; /* cout << sizeof(Node2) << endl;*/ }</span>
输出结果:32
原因:double(8) > int(4) > bool(1)
所以在double出现之前采用int,原结构体每个成员变量内存分配为:1、4、1、8、1
故1扩展为4,4保持不变,第二个1必须扩展为8,这样1(4) + 4(4) + 1(8) = 16才能被8整除,最后一个1扩展为8.
总共内存4+4+8+8+8 = 32.
示例2:
<span style="font-size:18px;">#include <iostream> using namespace std; struct Node1{ bool m1; bool m3; int m2; double m4; bool m5; }; // struct Node2{ // char m1; // char m2; // int m3; // }; int main() { cout << sizeof(Node1) << endl; /* cout << sizeof(Node2) << endl;*/ }</span>输出结果:24
原因:参考第一条
示例3:数组
<span style="font-size:18px;">#include <iostream> using namespace std; // // struct Node1{ // bool m1; // bool m3; // int m2; // double m4; // bool m5; // }; struct Node2{ char m1; char m2[6]; }; int main() { /* cout << sizeof(Node1) << endl;*/ cout << sizeof(Node2) << endl; }</span>
结果:7
原因:char数组不可看成一个对齐整体,Node2对齐基于1;故结果为7;
示例4:结构体中的结构体
<span style="font-size:18px;">#include <iostream> using namespace std; struct Node1{ char m1; double m2; char m3; }; struct Node2{ char m1; Node1 m2; }; int main() { /* cout << sizeof(Node1) << endl;*/ cout << sizeof(Node2) << endl; }</span>
输出结果:32
原因:
Node1为24,这个参考示例1;
但是Node1中的对齐基数是8;因为Node2中只有char m1,基数为1小于Node1的基数8;
所以采取Node1的对齐基数8;但是Node1是一个整体,不能将其填充部分的内容分给Node2中的m1使用。故
m1必须同样分配8字节给他,总字节数;8+24=32
内存对齐方式
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。