位操作实现内存对齐及其原理

内存对齐:

#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,那么就得到对齐后的数字啦。

 

其实用一句话高度概括,就是用到了溢出原理

 

posted @ 2018-05-16 17:16  ExitQuit  阅读(522)  评论(0编辑  收藏  举报