Java 中的位运算与移位运算详解

作者:.D.. 时间:2022-03-10 09:34:19 

目录
  • 位运算

    • 按位“与” &

    • 按位“或” |

    • 异或 ^

  • 移位运算

    • 左移 <<

    • 右移 >>

    • 无符号右移 >>>

  • 总结

    位运算

    按位“与” &

    规则: 如果两个相应的二进制形式的对应的位数都为 1,则结果为 1;否则为 0;

    4 & 5

    4

    0000 0100

    5

    0000 0101

    按位与运算

    &

    4 & 5 = 4

    0000 0100

    1 * 2^2 = 4

    -4 & 5

    -4

    1111 1100

    5

    0000 0101

    按位与运算

    &

    规则:运算结果符号位是1,为负数, 需要减 1,再取反(其他运算也要遵循)

    -4 & 5 = 4

    0000 0100

    1 * 2^2 = -4

    1.正数直接取二进制运算

    2.负数取反加一得补码再运算,得到的结果符号位为 0,不需要做任何操作直接给出结果

    按位“或” |

    规则: 有 1 为 1;否则为 0;

    4 | 5

    4

    0000 0100

    5

    0000 0101

    按位或运算


    4 | 5 = 5

    0000 0101

    1 * 2^0 + 1 * 2^2 = 5

    -4 | 5

    -4

    1111 1100

    5

    0000 0101

    按位或运算


    规则:运算结果符号位是1,为负数, 需要减 1,再取反(其他运算也要遵循)

    -4 | 5 =

    1111 1101

    减1

    1111 1100

    取反

    -0000 0011

    -4 | 5 = -3

    1 * 2^0 + 1 * 2^1 = -3

    异或 ^

    规则: 相同为 0;不同为 1;

    4 ^ 5

    4

    0000 0100

    5

    0000 0101

    按位异或运算

    ^

    4 ^ 5 = 1

    0000 0001

    1 * 2^0 = 1

    -4 ^ 5

    -4

    1111 1100

    5

    0000 0101

    按位异或运算

    ^

    规则:运算结果符号位是1,为负数, 需要减 1,再取反(其他运算也要遵循)

    -4 ^ 5 =

    1111 1001

    减1

    1111 1000

    取反

    -0000 0111

    -4 ^ 5 = -7

    1 * 2^0 + 1 * 2^1 + 1 * 2^2 = -7

    移位运算

    左移 <<

    规则: 右边空出的位用 0 填补高位,左移溢出则舍弃该高位。

    8 << 2

    8

    0000 1000

    << 2

    0010 0000

    左移运算符

    <<

    结果

    8 << 2 = 32

    1 * 2^5 = 32

    -8 << 2

    -8

    1111 1000

    << 2

    1110 0000

    左移运算

    <<

    规则:运算结果符号位是1,为负数, 需要减 1,再取反(其他运算也要遵循)

    减1

    1101 1111

    取反

    -0010 0000

    -8 << 2 = -32

    1 * 2^5 = -32

    右移 >>

    规则: 左边空出的位正数用 0 负数 1 填补,右移溢出则舍弃该低位。

    8 >> 2

    8

    0000 1000

    >> 2

    0000 0010

    左移运算符

    >>

    结果

    8 >> 2 = 2

    1 * 2^1 = 2

    -8 >> 2

    -8

    1111 1000

    >> 2

    1111 1110

    左移运算

    >>

    规则:运算结果符号位是1,为负数, 需要减 1,再取反(其他运算也要遵循)

    减1

    1111 1101

    取反

    -0000 0010

    -8 >> 2 = -2

    1 * 2^1 = -2

    无符号右移 >>>

    规则: 正数与右移规则一样;负数无符号右移,在高位补 0

    8 >>> 2

    8

    0000 1000

    >> 2

    0000 0010

    无符号右移运算符

    >>>

    结果

    8 >>> 2 = 2

    1 * 2^1 = 2

    -8 >>> 2

    -8

    1111 1111 1111 1111 1111 1111 1111 1000

    >>> 2

    0011 1111 1111 1111 1111 1111 1111 1110

    无符号右移运算符

    >>>

    规则:运算结果符号位是1,为负数, 需要减 1,再取反(其他运算也要遵循)

    减1

    -

    取反

    -

    -8 >>> 2 = 1073741822

    1073741822

    总结

    本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注脚本之家的更多内容!

    来源:https://blog.csdn.net/qq_29689487/article/details/122097670

    标签:Java,位运算,移位运算
    0
    投稿

    猜你喜欢

  • 剖析设计模式编程中C#对于组合模式的运用

    2023-04-09 07:48:17
  • Mybatis 中的sql批量修改方法实现

    2022-12-10 23:36:51
  • WPF如何自定义ProgressBar滚动条样式

    2021-08-02 13:31:44
  • android使用DataBinding来设置空状态

    2022-02-06 22:28:35
  • Java多线程事务回滚@Transactional失效处理方案

    2021-06-20 19:19:28
  • Java基本数据类型与类型转换实例分析

    2021-07-13 14:41:29
  • Java实现简易俄罗斯方块

    2022-12-18 14:07:58
  • C# 定时器定时更新的简单实例

    2023-01-08 12:45:50
  • 将本地的jar包打到Maven的仓库中实例

    2022-08-29 13:38:28
  • kotlin中EditText赋值Type mismatch方式

    2023-06-19 03:52:56
  • java中申请不定长度数组ArrayList的方法

    2023-02-24 17:37:37
  • Java热门笔试试题整理

    2023-11-25 08:56:33
  • Android实现登录邮箱的自动补全功能

    2021-12-18 04:02:36
  • C#实现对数组进行随机排序类实例

    2023-06-22 19:04:26
  • 带你了解mybatis如何实现读写分离

    2023-07-29 14:26:28
  • idea 模板编程知识小结

    2022-06-22 13:18:34
  • 深入讲解C#编程中嵌套类型和匿名类型的定义与使用

    2022-12-12 20:48:05
  • IDEA与模拟器安装调试失败的处理方法:INSTALL_PARSE_FAILED_NO_CERTIFICATES

    2022-08-25 13:57:53
  • java利用多线程和Socket实现猜拳游戏

    2022-10-03 08:03:30
  • WPF实现带筛选功能的DataGrid

    2022-05-07 07:48:56
  • asp之家 软件编程 m.aspxhome.com