欢迎访问 生活随笔!

生活随笔

当前位置: 首页 > 编程资源 > 编程问答 >内容正文

编程问答

内存分配地址的对齐

发布时间:2025/3/15 编程问答 28 豆豆
生活随笔 收集整理的这篇文章主要介绍了 内存分配地址的对齐 小编觉得挺不错的,现在分享给大家,帮大家做个参考.

void * memalign (size_t boundary, size_t size) 

看nginx源代码中的实现

#define ngx_align(d, a)     (((d) + (a - 1)) & ~(a - 1))

 返回的地址值为d后第一个是a的整数倍的值。

a是2的整数次幂。假设a = 2^n,即a的二进制表示中末尾有n个0。

假设返回的结果为A。则A-d的值在[0,a)之间,且A/a = 整数。

以二进制的形式可以比较清楚地看出其中的道理:

1)如果d正好是a的整数倍,则d的二进制表示中末尾n位全是0,加上a-1之后,只改变了末尾的n位,对d中的高位没有任何影响;在与(&)上a-1的取反,末尾的n位全成了0。对d的值没有任何改变。

2)如果d不是a的整数倍,则d加上a-1之后在n+1位会加1,剩余的n位在与a-1的取反按位与(&)之后全为0。此时的d值正好是a的整数倍,且与原来的d值之差不超过a。


总结

以上是生活随笔为你收集整理的内存分配地址的对齐的全部内容,希望文章能够帮你解决所遇到的问题。

如果觉得生活随笔网站内容还不错,欢迎将生活随笔推荐给好友。