c++ - 为什么按位 OR 和 AND 逻辑没有按预期工作?

标签 c++ c++11 enums bitwise-operators

我有下面的示例代码。我一直认为,对枚举值执行按位或运算可以让我检查结果(使用按位与运算)以查看结果中包含哪些枚举值,哪些不包含。

例如,如果我执行 result = mouse | headphone,然后我可以检查 agaist result & mouse == mouse 作为条件以了解 mouse 是否包含在 result 中.但似乎无论我 & 结果如何,比如 X,我总是以 X 结束。为什么?

在下面的代码中,我认为 if 应该失败,因为 straw 没有包含在 options 中,但它没有..

#include <iostream>
#include <iomanip>

using namespace std;

enum Stock  
{
    milk,
    choclate,
    tv,
    cable,
    mouse,
    fan,
    headphone,
    cup,
    straw,
    pen,
    candy,
    glasses,
    book,
    plug

};


int main()
{
    Stock options = static_cast<Stock>( static_cast<int>(mouse) | static_cast<int>(headphone)
                                            | static_cast<int>(cup) | static_cast<int>(pen)     );

    if ((static_cast<int>(loptions)) & (static_cast<int>(straw)) == static_cast<int>(straw))
    {
        cout << "bring straw!" << endl;
    }

    system("PAUSE");
    return 0;
}

编辑:

即使我为枚举值添加唯一位集,它也不起作用。对于下面的代码,当我期望它显示 "bring cup" 时,它忽略了两个 if() 语句:

enum Stock
{
    milk = 1,
    choclate = 2,
    tv = 4,
    cable = 8,
    mouse = 16,
    fan = 32,
    headphone = 64,
    cup = 128,
    straw = 256,
    pen = 512,
    candy = 1024,
    glasses = 2048,
    book = 4096,
    plug = 8192

};


int main()
{
    Stock options = static_cast<Stock>(static_cast<int>(mouse) | static_cast<int>(headphone)
                                        | static_cast<int>(cup) | static_cast<int>(pen));

    if ((static_cast<int>(options)) & (static_cast<int>(straw)) == static_cast<int>(straw))
    {
        cout << "bring straw!" << endl;
    }

    if ((static_cast<int>(options)) & (static_cast<int>(cup)) == static_cast<int>(cup))
    {
        cout << "bring cup!" << endl;
    }

    system("PAUSE");
    return 0;
}

最佳答案

要将枚举用作位集(或标志),您需要确保每个枚举值的二进制表示恰好包含设置为 1 的一位。换句话说,每个枚举值需要是 2 的幂。示例:

enum Stock  
{
    milk = 1,     // 0b0001
    choclate = 2, // 0b0010
    tv = 4,       // 0b0100
    cable = 8     // 0b1000
    // etc.
};

否则,按位逻辑运算符将无法区分某些值和其他值的某些组合。在原始代码中,chocolatetvcable 的值为 123 分别。在二进制中,即 011011。 ORing chocolatetv 产生 11 (0b01 | 0b10 == 0b11) 与 的值相同>电缆chocolatetv 的组合与 cable 标志没有区别。

但是c++提供了std::bitset .此类允许您以类似于位数组的方式轻松操作位集。然后,您可以只使用原始枚举并将每个枚举值用作位的索引

关于c++ - 为什么按位 OR 和 AND 逻辑没有按预期工作?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58293009/

相关文章:

c++ - 在回调函数中访问 QPushButton

c++ - 没有继承的友元 - 有什么选择?

c++ - 简单的 C++11 哈希函数无法编译

c++ - 错误: invalid conversion from ‘int’ to enum c++

c++ - BlackJack 卡 vector c++/随机数

c++ - 如何遍历通过引用传递的多个对象?

c++ - QTabWidget 奇怪的行为

c++ - 不使用 std::function 将捕获的 lambda 转换为函数指针

c++11 (MSVS2012) 正则表达式在多行 std::string 中查找文件名

c++ - 哪些枚举值在 C++14 中是未定义的行为,为什么?