位运算相关

按位与运算符(&)

参加运算的两个数据,按二进制位进行“与”运算。

运算规则:0&0=0; 0&1=0; 1&0=0; 1&1=1;

  即:两位同时为“1”,结果才为“1”,否则为0

例如:1&0=0;0&0=0.

        1               1                 0
      & 1             & 0               & 0
    一一一一一       一一一一一          一一一一一
        1               0                 0

比如计算15&10,首先15的二进制为:1111,10的二进制为1010(二进制,十进制和十六进制转化方法:点击这里),所以15&10为:

                    1 1 1 1
                  & 1 0 1 0
                 一一一一一一一
                    1 0 1 0

所以15&10=10。

另,负数按补码形式参加按位与运算。
“与运算”的特殊用途:
(1)清零。如果想将一个单元清零,即使其全部二进制位为0,只要与一个各位都为零的数值相与,结果为零。
(2)取一个数中指定位
方法:找一个数,对应X要取的位,该数的对应位为1,其余位为零,此数与X进行“与运算”可以得到X中的指定位。
例:设X=10101110,
取X的低4位,用 X & 0000 1111 = 00001110 即可得到;
还可用来取X的2、4、6位。

或运算:( | )

参加运算的两个对象,按二进制位进行“或”运算。

运算规则:0|0=0; 0|1=1; 1|0=1; 1|1=1;

 即 :参加运算的两个对象只要有一个为1,其值为1。

例如: 1|1=1;1|0=1;0|0=0.
 

        1               1                  0
      | 1             | 0                | 0
    一一一一一       一一一一一          一一一一一
        1               1                  0

比如计算15|10,首先15的二进制为:1111,10的二进制为1010,所以15|10为:

                    1 1 1 1
                  | 1 0 1 0
                 一一一一一一一
                    1 1 1 1

所以15|10=15。

另,负数按补码形式参加按位或运算。
“或运算”特殊作用:
(1)常用来对一个数据的某些位置1。
方法:找到一个数,对应X要置1的位,该数的对应位为1,其余位为零。此数与X相或可使X中的某些位置1。
例:将X=10100000的低4位置1 ,用X | 0000 1111 = 1010 1111即可得到。

异或运算符( ^ )

参加运算的两个数据,按二进制位进行“异或”运算。

运算规则:0^0=0; 0^1=1; 1^0=1; 1^1=0;

即:参加运算的两个对象,如果两个相应位为“异”(值不同),则该位结果为1,否则为0。

        1               1                  0
      ^ 1             ^ 0                ^ 0
    一一一一一       一一一一一          一一一一一
        0               1                  0

比如计算15^10,首先15的二进制为:1111,10的二进制为1010,所以15^10为:

                    1 1 1 1
                  ^ 1 0 1 0
                一一一一一一一
                    0 1 0 1

所以15^10=5

异或运算”的特殊作用:

(1)使特定位翻转找一个数,对应X要翻转的各位,该数的对应位为1,其余位为零,此数与X对应位异或即可。

例:X=10101110,使X低4位翻转,用X ^0000 1111 = 1010 0001即可得到。

(2)与0相异或,保留原值 ,X ^ 00000000 = 1010 1110。

下面重点说一下按位异或,异或其实就是不进位加法,如1+1=0,,0+0=0,1+0=1。

异或的几条性质:
1、交换律

2、结合律(即(a^b)^c == a^(b^c))

3、对于任何数x,都有x^x=0,x^0=x

4、自反性: a^b^b=a^0=a;

取反运算:( ~ )

取反运算的操作符为~,为单目运算符。取反运算符顾名思义,就是将一个整数中位为1的变成0,位为0的变成1。即:~1=0;~0=1.

      ~ 1             ~ 0              
    一一一一一       一一一一一        
        0               1              

比如计算~10,首先10的二进制为:1010,~10为:

                  ~ 1 0 1 0
                一一一一一一一
                    0 1 0 1

~10=5。

右移运算符:( >> )

右移运算符为>>。将一个数a向右移动n位记为:a>>n。比如将12向右移动2位如何计算呢?12的二进制为00001100,那么右移动2位为:00000011,即3。 即12>>2为3。

右移动运算分为两种右移,一种为逻辑右移,在移动过程中,左边位用0填充。一种为算术右移,在移动过程中,左边用符号位来填充。 比如对于有符号数:10000011,对于逻辑右移,向右移动3位,那么左边用0填充,变成了:00010000。而对于算术右移,向右移动3位,那么左边用1(1为符号位)填充,变成了11110000。而对于01000011,算术右移3位,那么左边用0(0为符号位)填充,变成了00001000。 在C语言中,右移运算符为算术右移运算符,即左边用符号位来填充。

左移运算符:( << )

左移运算符为《。将一个数a向左移动n位记为:a《n。 比如将12向左移动2位如何计算呢?12的二进制为00001100,那么左移动2位为:00110000。 无论左移还是右移,都需要用0或者1去填充移动之后空位。在左移的过程中,右边一律用0去填充。左移就没有右移那样分为逻辑右移和算术右移。 比如,将10左移2位,由于10的二进制为:00001010,那么左移2位,右边用零填充的结果为:00101000。 将一个数左移N位相当于将一个数乘以2^N,而将一个数右移N位相当于将这个数除以2^N。

一些常见的二进制位的变换操作如下图:
这里写图片描述

转:https://blog.csdn.net/u012713968/article/details/50481680 https://blog.csdn.net/sinat_35121480/article/details/53510793

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值