一、按位或运算
位与运算符是一个二元的运算符,也就是有两个操作数,表示为x | y。
参与|运算的两个二进制位有一个为 1 时,结果就为 1,两个都为 0 时结果才为 0。
因此,可以得到的结论:
- 无论是0或1,只要位或上1,就变成1;
- 只有当两个操作数都是0的时候,才变成0;
C语言中不能直接使用二进制,| 两边的操作数可以是十进制、八进制、十六进制,它们在内存中最终都是以二进制形式存储,| 就是对这些内存中的二进制位进行运算。
C语言中用0b前缀表示为二进制数。
两个正数的与运算我们会了,那还有负数的与运算是怎么搞的呢?
这就要涉及到 正数和负数在内存中的存储形式方面的知识了。
加法和减法是计算机中最基本的运算,为了提高加减法的运算效率。
在计算机内存中,整数一律采用补码的形式来存储。
原码(在最前面的符号位中,0表示正数,1表示负数)
反码 (正数的反码就是自身,负数的反码除符号位外,其他各位求反)
补码 (正数的补码还是自身,负数的补码,符号位不变,其余取反,然后最低为加1)
正数的补码还是它本身,负数的补码是其反码加 1。
这意味着,当读取整数时还要采用逆向的转换,也就是将补码转换为原码。
1111 1111 -- 1111 1111 -- 1111 1111 -- 1111 0111 (-9 在内存中的存储)
| 0000 0000 -- 0000 0000 -- 0000 0000 -- 0000 0101 (5 在内存中的存储)
-----------------------------------------------------------------------------------
1111 1111 -- 1111 1111 -- 1111 1111 -- 1111 0111 (-9 在内存中的存储)
-9 & 5的结果是 5。
二、位或运算符的应用
- 设置标记位。(判断低位第3位如果为0,则将它置为1---> x | 0b100)
- 置空标记位。(判断低位第3位如果为1,则将它置为0--->(x | 0b100) - 0b100,这里不直接减去的原因是首先要保证那一位为1,否则贸然减会产生借位 )
- 按位或运算可以用来将某些位置 1,或者保留某些位。