美文网首页
Java 位运算

Java 位运算

作者: micki_zhou | 来源:发表于2018-08-30 17:21 被阅读33次

    首先,在Java中,运算符有以下这些:

    • 按位与 &
    • 按位或 |
    • 按位异或 ^
    • 按位非 ~
    • 左移 <<
    • 右移 >>
    • 无符号右移 >>>

    好了,我们一个个来,先说简单的

    1. 按位与 &

    如果相对应位都是1,则结果为1,否则为0 。

    说完了概念,我们得举个例子

    比如:6 & 3

    int 类型的 6 二进制为 0000 0000 0000 0000 0000 0000 0000 0110
    int 类型的 3 二进制为 0000 0000 0000 0000 0000 0000 0000 0011
    所以运算的结果等于:0000 0000 0000 0000 0000 0000 0000 0010 十进制就是2

    2. 按位或 |

    如果相对应位都是0,则结果为0,否则为1。

    比如:8 | 5

    int 类型的 8 二进制为 0000 0000 0000 0000 0000 0000 0000 1000
    int 类型的 5 二进制为 0000 0000 0000 0000 0000 0000 0000 0101
    所以运算的结果等于:0000 0000 0000 0000 0000 0000 0000 1101 十进制就是13

    3. 按位异或 ^

    如果相对应位值相同,则结果为0,否则为1 。

    比如:9 ^ 3

    int 类型的 9 二进制为 0000 0000 0000 0000 0000 0000 0000 1001
    int 类型的 3 二进制为 0000 0000 0000 0000 0000 0000 0000 0011
    所以运算的结果等于:0000 0000 0000 0000 0000 0000 0000 1010 十进制就是10

    4. 按位非 ~

    翻转操作数的每一位,即0变成1,1变成0

    比如:~9

    int 类型的 9 二进制为 0000 0000 0000 0000 0000 0000 0000 1001
    ~9运算结果为 1111 1111 1111 1111 1111 1111 1111 0110

    5. 左移 <<

    左操作数按位左移右操作数指定的位数,低位补0。

    比如:5 << 3,其中5就是左操作数,3是向左移动的位数

    int 类型的 5 二进制为 0000 0000 0000 0000 0000 0000 0000 0101,左移三位的结果是:0000 0000 0000 0000 0000 0000 0010 1000,转换成十进制为:40。所以 5 << 3 的结果是 40.

    6. 右移 >>

    左操作数按位右移右操作数指定的位数,高位补符号,也就是如果是正数,高位补0,负数,高位补1。

    比如:8 >> 2

    int 类型的 8 二进制为 0000 0000 0000 0000 0000 0000 1000,右移两位的结果是:0000 0000 0000 0000 0000 0000 0000 0010,十进制为:2。所以 8 >> 2,结果是2。

    再举一个负数的例子:-8 >> 2

    int 类型的 -8 二进制为 1000 0000 0000 0000 0000 0000 0000 1000,这是原码,负数在计算机中的表现形式是补码的形式,所以还得转成补码(关于原码、反码、补码的知识,参考我另一篇文章)。-8 的补码是:1111 1111 1111 1111 1111 1111 1111 1000,右移两位,高位补1的结果是:1111 1111 1111 1111 1111 1111 1111 1110。再把补码转回原码:1000 0000 0000 0000 0000 0000 0000 0010。十进制为 -2。所以 -8 >> 2,结果是-2。

    7. 无符号右移 >>>

    跟右移一样,区别在于,无论正数还是负数,高位都补0。

    相关文章

      网友评论

          本文标题:Java 位运算

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