不仅是8,2^N次方都是可以。
解释:如输入9 ;那所求就是9+7-多余的部分,多余就是二进制的最后三位,所以答案是 ((m+7) & ~7)
ps:最后三位为0一定是8的倍数。
enum {_ALIGN = 8}; //设定上调边界为8(例如客户端输入30,调为32)
static size_t round_up(size_t bytes){
讯享网讯享网//将bytes上调至8的倍数,例如30,则(30 + 7)&~(7) = 32; //&运算(and运算): 相同位的两个数字都为1,则为1;若有一个不为1,则为0 //~取反. //()&(000)==32 return (((bytes) + (size_t) _ALIGN-1) & ~((size_t) _ALIGN - 1));
讯享网

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请联系我们,一经查实,本站将立刻删除。
如需转载请保留出处:https://51itzy.com/kjqy/119226.html