C/C++数据对齐汇总
2015-07-01 09:17
176 查看
C/C++数据对齐汇总
这里用两句话总结数据对齐的原则:
(1)对于n字节的元素(n=2,4,8,...),它的首地址能被n整除,才干获得最好的性能;
(2)如果len为结构体中长度最长的变量,size为CPU(处理器)的位数,对齐规则:
若len < size,则以len为单位对齐
若len >= size,则以size为单位对齐
这里不考虑指定对齐方式的情况。
測试
理解起来也不难,普通情况下。地址总线总是依照对齐后的地址来訪问。比如你想得到0x0000 0001開始的4字节内容,系统首先要以0x0000 0000開始,获得一个4字节,然后从中去除三字节。接着又以0x0000 0004開始,取出一个四字节,然后 取出一字节,两次组合你想得到的内容,然而假设初始地址一開始就是0x0000
0000那么就仅仅要一次即可了。所以对于B来说,按四字节对齐如果i的地址是0x0000 0000 那么为了一次取出j那么j的地址必须为0x0000 0004,因为四字节对齐k也要占四字节。而A中如果j的地址是0x0000 0000,那么i为0x0000 0004非常合理,且当k地址为0x0000 0002时相同能够一次取出,所以一共8字节。
对于sizeof有个须要注意的地方:
这里用两句话总结数据对齐的原则:
(1)对于n字节的元素(n=2,4,8,...),它的首地址能被n整除,才干获得最好的性能;
(2)如果len为结构体中长度最长的变量,size为CPU(处理器)的位数,对齐规则:
若len < size,则以len为单位对齐
若len >= size,则以size为单位对齐
这里不考虑指定对齐方式的情况。
測试
struct B{ bool i; int j; bool k; }; | struct A{ int j; bool i; bool k; }; |
cout<<sizeof(B)<<endl; cout<<sizeof(A)<<endl; |
输出结果: 12 8 |
0000那么就仅仅要一次即可了。所以对于B来说,按四字节对齐如果i的地址是0x0000 0000 那么为了一次取出j那么j的地址必须为0x0000 0004,因为四字节对齐k也要占四字节。而A中如果j的地址是0x0000 0000,那么i为0x0000 0004非常合理,且当k地址为0x0000 0002时相同能够一次取出,所以一共8字节。
对于sizeof有个须要注意的地方:
struct C{ int a; static int b; }; cout<<sizeof(C)<<endl。 | 结果:4 解释:由于静态变量是存放在全局区,而sizeof计算栈中分配的大小,是不会计算在内的,全部结果为4. |
相关文章推荐
- OJ第三批——Problem L: C++继承(改错题)
- 浅谈VC++中的内联
- OJ第三批——Problem K:C++ 长方体继承自矩形
- 一个小巧的C++Log输出到文件类 (转)
- 第十七周oj刷题——Problem A: 实现复数类中的加运算符重载【C++运算符重载】
- OJ第三批——Problem J:C++复数运算符重载(+与<<)
- c语言 图像显示jpeg
- [C++ primer]第六章笔记-函数
- C++ 大规模程序设计 之 组件
- C语言字符串替换函数(strrpl)
- C语言编程
- C语言 基础60题(1)
- c++学习 - int 和 string 的相互转换
- 黑马程序员——C语言基础学习(一)---C语言中的基本概念总结
- c语言--基础001--while循环
- 在什么情况下,Java比C++慢很多?
- C++错误
- 0-1背包问题与动态规划的C/C++代码
- 全局变量的定义
- C++ 智能指针详解