如何找出内存访问粒度
How to find out memory access granularity?
我已经阅读了这篇关于对齐的文章:http://www.ibm.com/developerworks/library/pa-dalign/
出现的问题是,如何找出特定处理器的内存访问粒度?
例如英特尔至强。不幸的是,当我尝试"内存访问粒度英特尔至强"或"内存对齐英特尔至强"时,谷歌对我没有帮助。
对于至强,请查看英特尔优化手册(谷歌)。粗略地说,体系结构希望数据类型与其大小或处理器的本机宽度中的较大值对齐。所以 x86 需要 4 字节对齐,但__m128应该是 16 字节对齐。x64 需要 8 字节对齐。不过,这不是一个硬性规定,因为一些 64 位架构只关心 4 字节对齐。
还有一件事:至强是一个商标,而不是一个架构。事实上,已经有多种架构作为至强销售。因此,"内存对齐英特尔至强"不会给您太多;"内存对齐x64"会给你很多。在同一架构的多个实现中,内存对齐要求将几乎相同。
相关文章:
- 通过方法访问结构
- 使用不带参数的函数访问结构元素
- 如果我只是不访问queue_front节点的子节点,而是将它们推到队列中呢?还是BFS吗
- 用于访问容器<T>数据成员的正确 API
- 访问者访问变体并返回不同类型时出错
- 尝试通过多个向量访问变量时,向量下标超出范围
- 无法访问嵌套类.类的使用无效
- 写入位置0x0000000C时发生访问冲突
- 我们可以访问一个不存在的联盟的成员吗
- C++从另一个类访问公共静态向量的正确方法是什么
- 我的简单if-else语句是如何无法访问的代码
- 从C++dll访问C#中的一行主要参数
- 概念TS检查忽略私有访问修饰符
- 访问被拒绝后,c++中的故障保护代码
- 在c++中访问int到类对象的映射时出错
- 我想访问std::unique_ptr中的一个特定元素
- 为什么示例代码访问IUnknown中已删除的内存
- C++:无法访问声明的受保护成员
- 细粒度访问说明符 c++
- 如何找出内存访问粒度