内存未对齐(Unaligned access mips sh4linux QtWebkit)导致性能降低及其处理

    内存未对齐是指cpu要读取N字节数据,但数据的起始地址不能被N所整除,导致效率降低,甚至异常的出现。例如当cpu读取一个int类型的变量,而变量地址是0x10005的时候就产生未对齐访问。

自然对齐:

    N字节的数据类型需要放在起始地址为被N整除的地址这称为自然对齐。并不是所有体系结构的计算机带都要求自然对齐,有的可以指定对齐方式。但是为了达到好的可移植性编写代码的时候最好都用自然对齐方式。

未对齐的影响

    未对齐的内存访问在不同的体系结构中会有不同的效果:有一些计算机可以透明的处理未对齐访问,但效率会降低很多;有一些计算机会产生异常,然后调用一个异常处理程序改正错误;有一些计算机产生异常,但是没有办法校正错误;有一些计算机则没有办法处理未对齐访问,而直接读取不正确的内存地址,造成难以察觉的代码漏洞。

编译器的影响:

    一般情况下编译器可以通过填充(padding)使得数据结构满足对齐要求。例如一下结构:

    Struct foo{

        U16 field1;

        U32 field2;

        U8 field3;

}

假设数据起始地址是0x10000.编译器在field1后填充2个字节使field2保持对齐,最后在field3后填充3个字节使整个数据结构4对齐,全部结构体占用空间为12字节。

导致未对齐访问的原因:

既然编译器能够自动对齐数据结构,导致内存未对齐访问的原因是什么?未对齐访问的

必要条件:指针强制类型转换且小数据转大数据。例如:

unsigned

  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个简单的C++程序,用于测试边界对齐和边界对齐对程序性能的影响: ```c++ #include <iostream> #include <chrono> struct AlignStruct { char c1; int i; char c2; }; struct UnalignStruct { char c1; int i __attribute__((packed)); char c2; }; int main() { // 边界对齐 AlignStruct align_struct; auto start = std::chrono::high_resolution_clock::now(); for (int i = 0; i < 1000000000; i++) { align_struct.i = 1; } auto end = std::chrono::high_resolution_clock::now(); std::cout << "aligned struct: " << std::chrono::duration_cast<std::chrono::microseconds>(end - start).count() << " microseconds" << std::endl; // 边界对齐 UnalignStruct unalign_struct; start = std::chrono::high_resolution_clock::now(); for (int i = 0; i < 1000000000; i++) { unalign_struct.i = 1; } end = std::chrono::high_resolution_clock::now(); std::cout << "unaligned struct: " << std::chrono::duration_cast<std::chrono::microseconds>(end - start).count() << " microseconds" << std::endl; return 0; } ``` 在这个程序中,我们定义了两个结构体:`AlignStruct`和`UnalignStruct`,分别表示边界对齐和边界对齐。然后,我们分别对这两个结构体中的`int`类型变量进行赋值操作,并记录程序运行时间,最后输出运行时间的差异。 在我的机器上运行这个程序,输出结果如下: ``` aligned struct: 601 microseconds unaligned struct: 1258 microseconds ``` 可以看到,边界对齐的结构体访问速度比边界对齐的结构体快了一倍以上,这说明边界对齐对程序性能的影响是非常显著的。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值