JSRUN 用代码说话

位运算符

编辑教程

位运算符

位运算符作用于位,并逐位执行操作。&、 | 和 ^ 的真值表如下所示:

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
JSRUN闪电教程系统是国内最先开创的教程维护系统, 所有工程师都可以参与共同维护的闪电教程,让知识的积累变得统一完整、自成体系。 大家可以一起参与进共编,让零散的知识点帮助更多的人。
X
支付宝
9.99
无法付款,请点击这里
金额: 0
备注:
转账时请填写正确的金额和备注信息,到账由人工处理,可能需要较长时间
如有疑问请联系QQ:565830900
正在生成二维码, 此过程可能需要15秒钟