本篇内容介绍了“Java中的位运算与移位运算有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
位运算
按位“与” &
规则: 如果两个相应的二进制形式的对应的位数都为 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 |
正数直接取二进制运算
负数取反加一得补码再运算,得到的结果符号位为 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 |
“Java中的位运算与移位运算有哪些”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!