c – 缓存行对齐内存分配是否有效?
发布时间:2020-12-16 05:42:07 所属栏目:百科 来源:网络整理
导读:我只是了解对齐内存分配的基本想法.但是我并不关心对齐问题,因为我不是汇编程序员,也没有MMX / SIMD的经验.我认为这是过早的优化之一. 这些天,人们越来越多地关于缓存命中,缓存一致性,大小优化等.一些源代码甚至将内存明确对齐在CPU缓存线上. 坦白说,我不知
我只是了解对齐内存分配的基本想法.但是我并不关心对齐问题,因为我不是汇编程序员,也没有MMX / SIMD的经验.我认为这是过早的优化之一.
这些天,人们越来越多地关于缓存命中,缓存一致性,大小优化等.一些源代码甚至将内存明确对齐在CPU缓存线上. 坦白说,我不知道i7 CPU的缓存行大小是多少.我知道大尺寸对齐将不会有任何伤害.但是,如果没有SIMD,它会真的有所回报吗? 假设程序中有100000个100字节的数据.并且访问这些数据是程序中最密集的工作. 如果我们更改数据结构,并使所有100字节大小的数据对齐16字节,是否可以获得显着的性能增益? 10%? 5%? 解决方法
关于高速缓存行对齐的大多数讨论涉及使用许多线程的高性能计算,并将可伸缩性尽可能接近线性.在这些讨论中,缓存行对齐的原因是为了防止对一个数据变量的写入使得高速缓存行无效,该缓存行也包含不同线程使用的另一个变量.
因此,除非您正在尝试编写可扩展到大量处理器内核的代码,否则高速缓存行对齐可能对您来说无关紧要.但再次测试一下,看看. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |