美文网首页小象education
Java 位运算(左、右,无符号右移位、按位与、按位或、按位非、

Java 位运算(左、右,无符号右移位、按位与、按位或、按位非、

作者: 青丝如梦 | 来源:发表于2018-06-28 17:30 被阅读0次

计算机对有符号数(包括浮点数)的表示有三种方法:原码、反码和补码,补码=反码+1。在二进制里,是用 0 和 1 来表示正负的,最高位为符号位,最高位为 1 代表负数,最高位为 0 代表正数。

在 Java 中声明两个 int 类型的变量:

int a = 9; 
int b = -9; 

那么 a 在计算机中的二进制形式则是:
0000 0000 0000 0000 0000 0000 0000 1001

b 在计算机中的二进制形式则是:
1111 1111 1111 1111 1111 1111 1111 0111

Java 查看 int 类型二进制形式的方法:Integer.toBinaryString( -9 )
Java int 类型的长度是32,所以 a 和 b 的长度都是 32 位

正数的二进制转换规则:
将正的十进制数除以二,得到的商再除以二,依次类推直到商为零或一时为止,然后在旁边标出各步的余数,最后倒着写出来,高位补零

计算42的二进制数
那么 42 的二进制形式就是 101010

负数的二进制转换规则:
1. 先将 -9 的绝对值转为二进制:
0000 0000 0000 0000 0000 0000 0000 1001
2. 将该二进制反码:
1111 1111 1111 1111 1111 1111 1111 0110
3. 将反码后的值加1:
1111 1111 1111 1111 1111 1111 1111 0111

下面就以 a 和 b 变量为例来进行运算:

位运算符

左移运算符 <<
a << 2

1. 将      0000 0000 0000 0000 0000 0000 0000 1001 进行左移两位,低位补 0
2. 结果为:0000 0000 0000 0000 0000 0000 0010 0100 = 36

b << 2

1. b 是负数,先将 b(-9)的绝对值转为二进制:
              0000 0000 0000 0000 0000 0000 0000 1001
2. 反码: 1111 1111 1111 1111 1111 1111 1111 0110
3. 再将反码后的值加 1:1111 1111 1111 1111 1111 1111 1111 0111
4. 进行左移两位,低位补零
5. 结果为:1111 1111 1111 1111 1111 1111 1101 1100(-36的二进制格式)

“有符号”右移位运算符 >>(保留最高位符号位)
a >> 2

1. 将      0000 0000 0000 0000 0000 0000 0000 1001 进行右移两位,高位补 0
2. 结果为:0000 0000 0000 0000 0000 0000 0000 0010 = 2

b >> 2

1. b 是负数,先将 b(-9)的绝对值转为二进制:
              0000 0000 0000 0000 0000 0000 0000 1001
2. 反码: 1111 1111 1111 1111 1111 1111 1111 0110
3. 再将反码后的值加 1:1111 1111 1111 1111 1111 1111 1111 0111
4. 进行右移两位,高位补一
5. 结果为:1111 1111 1111 1111 1111 1111 1111 1101(-3的二进制格式)

“无符号”右移位运算符 >>>(不保留最高位符号位,最高位始终补 0)
a >>> 2

1. 将      0000 0000 0000 0000 0000 0000 0000 1001 进行右移两位,高位补 0
2. 结果为:0000 0000 0000 0000 0000 0000 0000 0010 = 2

b >>> 2

1. b 是负数,先将 b(-9)的绝对值转为二进制:
              0000 0000 0000 0000 0000 0000 0000 1001
2. 反码: 1111 1111 1111 1111 1111 1111 1111 0110
3. 再将反码后的值加 1:1111 1111 1111 1111 1111 1111 1111 0111
4. 进行右移两位,高位补零
5. 结果为:0011 1111 1111 1111 1111 1111 1111 1101 = 1073741821

按位与 &
9 & 11
参与运算的两个数的二进制值按位比较,只有两个操作数对应位同为 1 时,结果为 1,其余全为 0
9 的二进制数为: 0000 0000 0000 0000 0000 0000 0000 1001
11 的二进制数为:0000 0000 0000 0000 0000 0000 0000 1011
    运算结果为: 0000 0000 0000 0000 0000 0000 0000 1001 = 9

按位或 |
9 | 11
参与运算的两个数的二进制值按位比较,只有两个操作数对应位同为 0 时,结果为 0,其余全为 1
9 的二进制数为: 0000 0000 0000 0000 0000 0000 0000 1001
11 的二进制数为:0000 0000 0000 0000 0000 0000 0000 1011
    运算结果为: 0000 0000 0000 0000 0000 0000 0000 1011 = 11

按位非 ~
~11
11 的二进制数为:0000 0000 0000 0000 0000 0000 0000 1011
     把每一位全部取反
     运算结果为: 1111 1111 1111 1111 1111 1111 1111 0100(-12的二进制格式)

按位异或运算符 ^
9 ^ 2
参与运算的两个数的二进制值按位比较,如果两个相应位相同,则结果为 0,否则为 1
9 的二进制数为:0000 0000 0000 0000 0000 0000 0000 1001
2 的二进制数为:0000 0000 0000 0000 0000 0000 0000 0010
   运算结果为: 0000 0000 0000 0000 0000 0000 0000 1011 = 11

相关文章

  • Java 位运算(左、右,无符号右移位、按位与、按位或、按位非、

    计算机对有符号数(包括浮点数)的表示有三种方法:原码、反码和补码,补码=反码+1。在二进制里,是用 0 和 1 来...

  • 位运算

    运算符含义&按位与|按位或^按位异或~取反<<左位移>>右位移 按位与运算符(&)按位与运算将两个运算分量的对应位...

  • 位运算实用技巧(Java实现)

    1. Java支持的位运算符: &:按位与 |:按位或 ~:按位非(Esc下面那个键) ^:按位异或 <<:左位移...

  • 位运算:包括按位与(&)、按位或(|)、异或(^)、按位取反(~)以及移位(<<,>>)。“与”同为‘1’为‘...

  • 位运算

    名称符号 按位与 & 按位或 | 按位异或 ^ 按位取反 ~ 左移运算 << 右移运算 >> &按位与的用法(相同...

  • Java 位运算

    首先,在Java中,运算符有以下这些: 按位与 & 按位或 | 按位异或 ^ 按位非 ~ 左移 << 右移 >> ...

  • Java中位运算符的运用

    位运算符分为:按位与、按位或、按位异或、左移、右移,符号表示分别是:&、|、^、<<、>>,在Java或者Andr...

  • 位逻辑运算符

    一. 按位取反 二. 与符号(按位与&) 三. 或符号(|) 四. 异或符号(^) 相同为0, 不同为1 五. 右...

  • JavaScript基本概念之操作符——位操作符

    按位非(NOT) ~ 按位与(AND) & 按位或(OR) | 按位异或(XOR) ^ 左移 << 有符号右移 >...

  • ios 中的位运算

    位运算的符号:~ | & ^ << >>分别代表的是按位取反,按位或,按位与,按位异或,左移,右移 按位取反操作 ...

网友评论

    本文标题:Java 位运算(左、右,无符号右移位、按位与、按位或、按位非、

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