使用独占或if语句,C#

时间:2012-07-16 20:32:59

标签: c# if-statement xor

我搜索了网站和谷歌,但无法找到我想要的东西。我认为这很简单,但我对C#还不熟悉,所以我遇到了一些麻烦。

基本上,我有一个if语句来测试我所拥有的单选按钮的选择,这是通过单击按钮触发的。默认情况下,我没有任何选择,如果忘记选择一个MessageBox,我的程序将通知我。基本上,在做出选择之前,你不能做任何事情。

到目前为止,我只有3个单选按钮,但今天我又增加了一个,还有一些与新单元相关的代码,包括一个新功能。

我还在试图找出测试radioButton的最有效内存的方法。现在,是使用临时变量,还是使用if if语句?

if (pRKButton.Checked != true ^ hexButton.Checked != true ^ binaryButton.Checked != true)
        {
            MessageBox.Show("Choose a method of encryption.");
            return null;
        }
        else....//More Goes Here

我的主要问题是:为什么当我在if语句中再添加一个参数时,使用exclusive或者像这样;

if (pRKButton.Checked != true ^ hexButton.Checked != true ^ binaryButton.Checked != true ^ md5Button.Checked != true)

该程序没有注册我点击单选按钮的 ANY

此时我正在考虑制作一个列表框来保存所有值并选择选项,因为列表会增长。但我对于无法使用独占或超过3个参数的原因感到非常好奇。在任何程度上,我都不是数学家,但我更愿意了解更多。

2 个答案:

答案 0 :(得分:8)

在我讨论问题的主要部分之前,我想指出你实际上并不需要在这里使用XOR。当您有单选按钮时,只能选择零或一个。选择一个时,同一组中的其他组将自动取消选中。因此,您可以使用||来测试是否至少选择了一个。

if (pRKButton.Checked || hexButton.Checked || binaryButton.Checked)
{
   // At least one (i.e. exactly one) is checked.
}
else
{
   // None checked.
}

要回答问题的主要部分,您的代码会失败,因为当您选择了一个按钮时,您会获得false ^ true ^ true(注意您正在测试按钮未选中)。结果是错误的。但是当你有四个变量时,你会得到false ^ true ^ true ^ true,这是真的。

XOR并不意味着“只有一个是真的”,因为你似乎在思考。如果A,B,C的奇数是真的,则A XOR B XOR C为真。这与“恰好一个”不同,因为如果A,B和C中的所有三个都为真,则为真。

请参阅以下truth table以了解具有三个输入的链式XOR的行为:

A XOR B XOR C

答案 1 :(得分:2)

除了Mark Byer关于单选按钮功能的良好信息之外,您可能会担心您的代码会因为很长的if语句而变臭。

尝试使用LINQ简化:

container.Controls.OfType<RadioButton>().Any<RadioButton>(r => r.Checked);

根据要检查的任何单选按钮,它是真还是假。