这个操作符对两个整数的每一位进行比较,如果两个相应的位都为1,则结果为1,否则为0。
int a = 60; ? // 60 = 0010 1100 in binary ?
int b = 13; ? // 13 = 0000 1101 in binary ?
int c = a & b; // c = 0000 1100 = 12 in binary
这个操作符对两个整数的每一位进行比较,如果两个相应的位中有一个为1,则结果为1,否则为0。
int a = 60; ? // 60 = 0010 1100 ?
int b = 13; ? // 13 = 0000 1101 ?
int c = a | b; // c = 0010 1101 = 61
?
这个操作符对两个整数的每一位进行比较,如果两个相应的位中有一个为1且另一个为0,则结果为1,否则为0。
int a = 60; ? // 60 = 0010 1100 ?
int b = 13; ? // 13 = 0000 1101 ?
int c = a ^ b; // c = 0010 0001 = 49
?
这个操作符对一个整数的每一位进行取反操作。如果某一位是1,则结果为0;如果是0,则结果为1。
int a = 60; ? // 60 = 0010 1100 ?
int b = ~a; ? // b = -61 = 1101 0011 (-61的二进制补码)
规则:正数二进制左移右端补0,负数补码左移一,符号位不变,右端空位补零
左移是指将二进制位向左移动一位同时最后空出来的一位补零。下面以实例演示: 例如,十进制数字5,二进制为00000000000000000000000000000101,现左移一位,即变成00000000000000000000000000001010,转换成二进制数字应为10:再看负数,例如-5,左移一位后保留符号位不变,右端补零,应为-10.
分为:算数右移和逻辑右移
介绍:算数右移,计算机系统以算数右移为主
规则: 右移末尾舍弃,高位补符号位
仍看例子,例如正整数5,存储2进制为00000000000000000000000000000101,右移一位后变成00000000000000000000000000000010,对应十进制为2。
再例如负整数-5,左移后高位补符号位,低位舍弃,-5对应的原码:
10000000000000000000000000000101: 反码: 111111111111111111111111111111111010
,补码111111111111111111111111111111111011,补码右移1位后变成111111111111111111111111111111111101,对应的反码: 111111111111111111111111111111111100,对应的原码:
10000000000000000000000000000011,及二进制-3.
?
当且仅当两个操作数都为真时,逻辑与的结果才为真。
int a = 10; ?
int b = 20; ?
if (a > 5 && b > 10) { ?
? ? printf("Both conditions are true\n"); ?
}
只要有一个操作数为真,逻辑或的结果就为真。
int a = 10; ?
int b = 5; ?
if (a > 5 || b > 10) { ?
? ? printf("At least one of the conditions is true\n"); ?
}
逻辑非是对一个操作数的逻辑否定。如果操作数为真,则逻辑非的结果为假;如果操作数为假,则逻辑非的结果为真。
int a = 10; ?
if (!a > 5) { ?
? ? printf("The condition is false\n"); ?
}