字节对齐处理技巧

2014/05/26 10:48
阅读数 432

简介

所谓字节对齐问题,是指在内存中一个基本数值类型变量应该位于其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;
}



展开阅读全文
加载中
点击引领话题📣 发布并加入讨论🔥
打赏
0 评论
10 收藏
0
分享
返回顶部
顶部