位操作实现内存对齐及其原理
内存对齐:
#define MG_ALIGN(size, align) (((size) + (align) - 1) & ~((align) - 1))
原理:https://blog.csdn.net/fengbangyue/article/details/6531455
通俗解释下吧,假设对于 xxxx xxxx xxxx xxxx xxxx xxxx xxxx x100 调整到4的边界上。那么我对这个数字加3,将会导致一下效果:
1、如果最后两位为00,那么当然不会溢出。 2、如果最后两位大于0,那么肯定溢出。 3、溢出后,我们同时与上 1111 1111 1111 1111 1111 1111 1111 1100,那么就得到对齐后的数字啦。
其实用一句话高度概括,就是用到了溢出原理。