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
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
剖析设计模式编程中C#对于组合模式的运用
![](https://img.aspxhome.com/file/2023/4/100164_0s.png)
Mybatis 中的sql批量修改方法实现
WPF如何自定义ProgressBar滚动条样式
![](https://img.aspxhome.com/file/2023/7/86967_0s.png)
android使用DataBinding来设置空状态
![](https://img.aspxhome.com/file/2023/4/88344_0s.gif)
Java多线程事务回滚@Transactional失效处理方案
![](https://img.aspxhome.com/file/2023/2/82312_0s.png)
Java基本数据类型与类型转换实例分析
![](https://img.aspxhome.com/file/2023/8/71018_0s.png)
Java实现简易俄罗斯方块
![](https://img.aspxhome.com/file/2023/1/67471_0s.png)
C# 定时器定时更新的简单实例
将本地的jar包打到Maven的仓库中实例
kotlin中EditText赋值Type mismatch方式
![](https://img.aspxhome.com/file/2023/2/94282_0s.jpg)
java中申请不定长度数组ArrayList的方法
Java热门笔试试题整理
Android实现登录邮箱的自动补全功能
![](https://img.aspxhome.com/file/2023/7/91657_0s.jpg)
C#实现对数组进行随机排序类实例
带你了解mybatis如何实现读写分离
idea 模板编程知识小结
![](https://img.aspxhome.com/file/2023/6/86796_0s.png)
深入讲解C#编程中嵌套类型和匿名类型的定义与使用
IDEA与模拟器安装调试失败的处理方法:INSTALL_PARSE_FAILED_NO_CERTIFICATES
![](https://img.aspxhome.com/file/2023/2/75462_0s.png)
java利用多线程和Socket实现猜拳游戏
![](https://img.aspxhome.com/file/2023/9/64549_0s.jpg)
WPF实现带筛选功能的DataGrid
![](https://img.aspxhome.com/file/2023/0/76430_0s.png)