位运算

作者: 赵日天逢考必过 | 来源:发表于2019-10-23 23:45 被阅读0次

位运算小结(按位与、按位或、按位异或、取反、左移、右移)

位运算不管是在Java语言,还是在C语言中,或者其他语言,都是经常会用到的,所以本文也就不固定以某种语言来举例子了,原始点就从0、1开始。位运算主要包括按位与(&)、按位或(|)、按位异或(^)、取反()、左移(<<)、右移(>>)这几种,其中除了取反()以外,其他的都是二目运算符,即要求运算符左右两侧均有一个运算量。

1、补码

在总结按位运算前,有必要先介绍下补码的知识,我们知道当将一个十进制正整数转换为二进制数的时候,只需要通过除2取余的方法即可,但是怎么将一个十进制的负整数转换为二进制数呢?其实,负数是以补码的形式表示,其转换方式,简单的一句话就是:先按正数转换,然后取反加1。

要将十进制的-10用二进制表示,先将10用二进制表示:

0000 0000 0000 1010

取反:

1111 1111 1111 0101

加1:

1111 1111 1111 0110

所以,-10的二进制表示就是:1111 1111 1111 0110

2、按位与(&)

参加运算的两个数,换算为二进制(0、1)后,进行与运算。只有当相应位上的数都是1时,该位才取1,否则该为为0。

将10与-10进行按位与(&)运算:

0000 0000 0000 1010

1111 1111 1111 0110

-----------------------

0000 0000 0000 0010

所以:10 & -10 = 0000 0000 0000 0010

|

3、按位或(|)

参加运算的两个数,换算为二进制(0、1)后,进行或运算。只要相应位上存在1,那么该位就取1,均不为1,即为0。

将10与-10进行按位或(|)运算:

0000 0000 0000 1010

1111 1111 1111 0110

-----------------------

1111 1111 1111 1110

所以:10 | -10 = 1111 1111 1111 1110

|

4、按位异或(^)

参加运算的两个数,换算为二进制(0、1)后,进行异或运算。只有当相应位上的数字不相同时,该为才取1,若相同,即为0。

将10与-10进行按位异或(^)运算:

0000 0000 0000 1010

1111 1111 1111 0110

-----------------------

1111 1111 1111 1100

所以:10 ^ -10 = 1111 1111 1111 1100

|

可以看出,任何数与0异或,结果都是其本身。利用异或还可以实现一个很好的交换算法,用于交换两个数,算法如下:

a = a ^ b;

b = b ^ a;

a = a ^ b;

|

5、取反(~)

参加运算的两个数,换算为二进制(0、1)后,进行取反运算。每个位上都取相反值,1变成0,0变成1。

对10进行取反(~)运算:

0000 0000 0000 1010

---------------------

1111 1111 1111 0101

所以:~10 = 1111 1111 1111 0101

6、左移(<<)

参加运算的两个数,换算为二进制(0、1)后,进行左移运算,用来将一个数各二进制位全部向左移动若干位。

对10左移2位(就相当于在右边加2个0):

0000 0000 0000 1010

--------------------

0000 0000 0010 1000

所以:10 << 2 = 0000 0000 0010 1000 = 40

|

注意,观察可以发现,左移一位的结果就是原值乘2,左移两位的结果就是原值乘4。

7、右移(>>)

参加运算的两个数,换算为二进制(0、1)后,进行右移运算,用来将一个数各二进制位全部向右移动若干位。

对10右移2位(就相当于在左边加2个0):

0000 0000 0000 1010

--------------------

0000 0000 0000 0010

所以:10 >> 2 = 0000 0000 0000 0010 = 2

|

相关文章

  • 3、小众运算符の大课堂(一)

    较为简单の位运算符: & 位与运算| 位或运算^ 位异或运算~ 位取反运算 举例: 要做位运算,首先要把数据转...

  • 位运算及其应用

    内容概要: 位运算基本操作 基于位运算的状态压缩 位运算经典应用 位运算解N皇后问题 位运算 符号描述规则&与1&...

  • 位运算及用位运算实现权限控制

    请自行补习位运算相关知识 位运算 位运算示例 权限控制

  • 开发基础随笔之位运算符(Bitwise Operators)

    位运算符,属于算术运算符 按位逻辑运算符: 位移运算符: 位运算符的运算数只能是整数 位移运算符:按位左移 a<<...

  • 强大的位运算符

    位取反运算符 位取反运算符(~)是对所有位的数字进行取反操作位取反运算符.png 位与运算符 位与运算符(&)可以...

  • 位运算

    位运算 1. &:按位与 规律:一假则假任何位上的数和1相&得到的结果还是那个数 2. |:按位或 规律:一真则真...

  • 位运算

    https://leetcode.com/problems/gray-code/description/这个位运算...

  • 位运算

    位运算符比一般的算术运算符速度要快,而且可以实现一些算术运算符不能实现的功能。如果要开发高效率程序,位运算符是必不...

  • 位运算

    1.不用加减乘除做加法 解法:分为三步①各位相加不进位,即先按位异或;②做进位,按位与并左移位;③结果相加,直至没...

  • 位运算

    位运算不仅可以简化某些复杂的操作,而且具有更快的计算速度。典型的应用就是除法,交换两个数值,以及在一个数组中寻找只...

网友评论

      本文标题:位运算

      本文链接:https://www.haomeiwen.com/subject/zqefuctx.html