c# – MonoDevelop建议将if语句转换为按位运算

前端之家收集整理的这篇文章主要介绍了c# – MonoDevelop建议将if语句转换为按位运算前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
MonoDevelop建议转向:
if (someBoolVar)
    anotherBoolVar = true;

进入这个:

anotherBoolVar |= someBoolVar;

当我将anotherBoolVar设置为false时,它也会这样做:

if (someBoolVar)
    anotherBoolVar = false;

变为:

anotherBoolVar &= !someBoolVar;

有人可以解释这些陈述是如何平等的吗?

解决方法

好吧,功能上他们是等同的.

在第一种情况下,如果someBoolVar为true,则要将anotherBoolVar设置为true,无论anotherBoolVar当前具有什么值,替换表达式都会这样做.

这是短暂的:

anotherBoolVar = anotherBoolVar | someBoolVar;

第二个替换也与它替换的代码相同,并且简称:

anotherBoolVar = anotherBoolVar & (!someBoolVar);

在这种情况下,解决方案隐藏在布尔变量的“按位”性质中.使用反转值(〜反转someBoolVar)将有效地说“保留所有在!someBoolVar中设置的位并清除其余位”,这意味着如果someBoolVar为true,它将被反转为false,并且你将有效地清除了AnotherBoolVar.

现在,你应该这样做吗?

在我看来,没有.代码更具可读性.保持,甚至可能寻找一种方法让MonoDevelop不再建议这些东西.

猜你在找的C#相关文章