[短码基础] 神奇的位运算

无论是否喜欢短码编程,我觉得熟悉一些常用的位运算都会让你如虎添翼。最早我在学习C语言的时候,知道了对2的幂取模可以用位与的方式。后来看了《hacker's delight》,发现里面有那么多神奇的位运算,现在整理一下(陆续更新)。

 

1> 对2的幂取模

    设求m%n,n是2的幂,则 m%n == m&(n-1)

 

2> 析出x最右侧的1位(0111 1000 --> 0000 1000)

    x&-x

    注:

    a> 汇编代码是两条指令neg和and

    b> 有的人会写成x&(x^(x-1)),汇编代码是3条指令sub,xor,and

    c> 在gcc中开优化选项-O1或-O2或-O3,均会将代码编译成两条指令的形式

 

3> 析出x最右侧的0位(1110 0111 ----> 0000 1000)

    ~x&(x+1)

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值