位运算符
位运算符作用于位,并逐位执行操作。&、 | 和 ^ 的真值表如下所示:
| p | q | p & q | p丨q | p ^ q | 
| 0 | 0 | 0 | 0 | 0 | 
| 0 | 1 | 0 | 1 | 1 | 
| 1 | 1 | 1 | 1 | 0 | 
| 1 | 0 | 0 | 1 | 1 | 
假设如果 A = 60,且 B = 13,现在以二进制格式表示,它们如下所示:
A = 0011 1100
B = 0000 1101
-----------------
A&B = 0000 1100
A|B = 0011 1101
A^B = 0011 0001
~A  = 1100 0011
下表显示了 C 语言支持的位运算符。假设变量 A 的值为 60,变量 B 的值为 13,则:
| 运算符 | 描述 | 实例 | 
| & | 按位与操作,按二进制位进行“与”运算。运算规则: 0&0=0;   0&1=0; 1&0=0; 1&1=1; | (A & B) 将得到 12,即为 0000 1100 | 
| | | 按位或运算符,按二进制位进行“或”运算。  运算规则: 0丨0=0;   0丨1=1;  1丨0=1;  1丨1=1; | (A丨B) 将得到 61,即为 0011 1101 | 
| ^ | 异或运算符,按二进制位进行“异或”运算。运算规则: 0^0=0;  0^1=1;  1^0=1;   1^1=0 | (A ^ B) 将得到 49,即为 0011   0001 | 
| ~ | 取反运算符,按二进制位进行“取反”运算。运算规则: ~1=0   ~0=1; | (~A ) 将得到 -61,即为 1100 0011,2 的补码形式,带符号的二进制数。 | 
| << | 二进制左移运算符。左操作数的值向左移动右操作数指定的位数(左边的二进制位丢弃,右边补0)。 | A << 2 将得到 240,即为 1111 0000 | 
| >> | 二进制右移运算符。左操作数的值向右移动右操作数指定的位数(正数左补0,负数左补1,右边丢弃)。 | A >> 2 将得到 15,即为 0000 1111 | 
实例
请看下面的实例,了解 C 语言中所有可用的位运算符:
    #include <stdio.h>
    int main()
    {
       unsigned int a = 60; /* 60 = 0011 1100 */  
       unsigned int b = 13; /* 13 = 0000 1101 */
       int c = 0;           
       c = a & b;       /* 12 = 0000 1100 */ 
       printf("Line 1 - c 的值是 %d\n", c );
       c = a | b;       /* 61 = 0011 1101 */
       printf("Line 2 - c 的值是 %d\n", c );
       c = a ^ b;       /* 49 = 0011 0001 */
       printf("Line 3 - c 的值是 %d\n", c );
       c = ~a;          /*-61 = 1100 0011 */
       printf("Line 4 - c 的值是 %d\n", c );
       c = a << 2;     /* 240 = 1111 0000 */
       printf("Line 5 - c 的值是 %d\n", c );
       c = a >> 2;     /* 15 = 0000 1111 */
       printf("Line 6 - c 的值是 %d\n", c );
    }
当上面的代码被编译和执行时,它会产生下列结果:
Line 1 - c 的值是 12
Line 2 - c 的值是 61
Line 3 - c 的值是 49
Line 4 - c 的值是 -61
Line 5 - c 的值是 240
Line 6 - c 的值是 15