您的位置:首页 > 其它

处理字节对齐的函数

2013-08-15 16:16 169 查看
所谓字节对齐问题,是指在内存中一个基本数值类型变量应该位于其sizeof大小的整数倍边界上,换句话说,就是一个基本数值类型变量的地址能够被其sizeof大小所整除。比如,对于short类型,其地址应该能够2整除,而对于double类型,则要求能被8整除。

这样做是由CPU运算时获取值的特性决定的,现在,大多数CPU都能处理字节不对齐的问题,但对于一些嵌入式CPU,我们仍需加以重视,不然将导致程序出现异常,而且,从效率角度来讲,我们也应该避免字节不对齐的情况出现。

下面是一个将任意地址按照指定对齐大小进行向上对齐的函数:

char* make_align(char* src, size_t aligned)

{

return (src + aligned - 1) & ~(aligned - 1);

}
上述函数要求aligned必须为2的幂,比如4、8、16等,实际中我们也只会碰到这种情况,如果要按照任意字节对齐,可以采用如下函数:

char* make_align(char* src, size_t aligned)

{

return (src + aligned - 1) / aligned * aligned;

}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: