求一个数的临近的较大的2的整数次幂

偶然看到云风的http://blog.codingnow.com/2011/12/buddy_memory_allocation.html 代码,发现了一个比较巧妙的实现。

 

static inline int
is_pow_of_2(uint32_t x) {
 return !(x & (x-1));
}

static inline uint32_t
next_pow_of_2(uint32_t x) {
 if ( is_pow_of_2(x) )
  return x;
 x |= x>>1;
 x |= x>>2;
 x |= x>>4;
 x |= x>>8;
 x |= x>>16;
 return x+1;
}

  这里算法的意思是从最高bit位为1的位开始,从左边往右边复制bit位为1到相邻的bit位。考虑最差的情况,比如128,需要复制的次数比较多,只不过它已经是2的整数次幂,这里举个极端的例子,表明移动复制1的过程,理解算法的意思。

 

        1000  0000

|       0100 0000                   //复制1位

=      1100 0000

|        0011 0000                 //复制2位              

=      1111 0000

|        0000 1111                //复制4位

=       1111 1111

很清晰,很高效啊。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值