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