用按位运算符检查位设置

问题描述 投票:2回答:1

我有此来源C:

#include <stdio.h>

#define BLUE 1
#define GREEN 2
#define RED 4

int main(void) {
    unsigned short i;
    char *array[8] = { "000", "001", "010", "011", "100", "101", "110", "111"};

    for(i = 0x0000; i <= 0x0007; i++) {
        printf("%d) %s -> ", i, array[i]);
        if(i & (BLUE | GREEN))
            printf("V\n");
        else
            printf("F\n");  
    }

    printf("\n\n");

    for(i = 0x0000; i <= 0x0007; i++) {
        printf("%d) %s -> ", i, array[i]);
        if(!((i | (BLUE)) ^ (i | (GREEN))))
            printf("V\n");
        else
            printf("F\n");  
    }

    return 0;
}

通过程序的第一个FOR,我得到了关于表达式行为的真值表:

(i & (BLUE | GREEN))

也就是说,他们能够验证BLUE或GREEN位中的至少一位(或两者都设置为1。

现在,我想检查BLUE和GREEN位是否都为1。我设法用表达式来做到这一点:

(! ((i | (BLUE)) ^ (i | (GREEN)))))

但是我一点都不喜欢它!我以为我会用“〜”代替“!”但它不起作用。任何人都知道如何仅使用按位运算符可以完成此操作吗?

c bitwise-operators
1个回答
3
投票

我想检查BLUE和GREEN位是否都为1。

(i & (BLUE|GREEN)) == (BLUE|GREEN)

&应用于位组合将为您提供那些打开的位的子集。您知道可以通过查看结果是否为零(不是所有位都关闭)来测试其中的任何一个。要测试所有这些,只需测试结果是否与刚测试的位组合相同即可。

© www.soinside.com 2019 - 2024. All rights reserved.