慎用位运算

在许多古老的微处理器上, 位运算比加减运算略快, 通常位运算比乘除法运算要快很多。在现代架构中, 位运算的运算速度通常与加法运算相同(仍然快于乘法运算)。大多数时候,我们使用位运算是为了加快程序的执行或节省空间。使用位运算可以很巧妙的解决某些问题,例如前面两篇博客所介绍的使用位运算求整型变量的绝对值或相反数。然而,大多数时候我们是将位运算和其他运算放在一起进行,此时就需要格外注意运算符之间的优先级关系。

例如,加减运算的优先级是高于位运算的,即 以下表达式成立:

a & b + c == a & (b + c)

至于为什么?可能是设计者当初就想这样设计。感兴趣的可以看看Dennis M. Ritchie写的这篇回顾C语言发展的论文。回想起来,我因忘记他们之间存在优先级差别而吃过好几次亏,每次都花费好多时间去debug。如果不想花时间去记位运算与其他运算符之间的优先级,那就用括号吧,把需要优先计算的表达式用括号括起来。正如stack overflow上一位用户的回答:Because that's the way they designed it. Also, parentheses are cheap.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值