我的问题有两部分.
首先,作为这个地址空间的新手,我想知道一个地址的内存对齐方式是什么意思.我在谷歌搜索,但想在这里提出这个问题,因为我发现这里的答案非常有用.
我的问题的第二部分与对齐和编程有关:如何找到一个地址是否4字节对齐?
在某个地方我读:
if(address & 0x3) // for 32 bit register
但是我真的不知道如何检查4字节对齐.
有人可以详细解释吗?
编辑:这将是伟大的如果有人可以绘制这个主题的图画.
谢谢
解决方法
顺序地址是指内存中的顺序字节.
“4字节对齐”的地址是4个字节的倍数.换句话说,地址的二进制表示以两个零(00)结束,因为在二进制中,它是二进制值4(100b)的倍数.因此,对于4字节对齐地址的测试是:
if ( (address & 0x3) == 0 ) { // The address is 4-byte aligned here }
或简单地
if ( !(address & 0x3) ) { // The address is 4-byte aligned here }
0x3是二进制11,或是地址最低两位的掩码.
对齐很重要,因为如果数据项的地址对齐,某些cpu操作会更快.这是因为cpu是基于32位或64位字的.如果是4字节对齐,则少量数据(例如4字节)适合32位字.如果它不对齐,它可以跨越32位边界并需要额外的内存提取.现代cpu也有其他优化,以提高地址对齐数据的性能.
以下是有关alignment and speed主题的示例文章.
这里有一些很好的diagrams of alignment.