我最近遇到过几次:
if ((flags & PERFORM_DELETION_CONCURRENTLY) == PERFORM_DELETION_CONCURRENTLY)
...
额外比较的原因是什么?为什么不这样做?
if (flags & PERFORM_DELETION_CONCURRENTLY)
...
我的猜测是,从编译器更严格的过去时代开始,将警告静音是一种遗留的习惯。
掩码中也有可能设置了多个位。在这种情况下,这两个比较具有不同的语义。
准确地说,如果PERFORM_DELETION_CONCURRENTLY
中的所有位都设置为 flags
,则条件为真。执行此操作的一种稍微更有效的方法(在某些架构上)是if ((~flags & PERFORM_DELETION_CONCURRENTLY) == 0)
...我将其隐藏在标准头文件中的ALL_BITS_SET
宏中,这也使代码更具可读性/可理解性。