在Java语言中,二进制数使用补码表示,最高位为符号位,正数的符号位为0,负数为1。补码的表示需要满足如下要求。
(1)正数的最高位为0,其余各位代表数值本身(二进制数)。
(2)对于负数,通过对该数绝对值的补码按位取反,再对整个数加1。
位移运算符:
<< 左位移(左移运算是将操作数二进制值逐位左移若干位,左移过程中符号位不变 ,高位溢出并舍弃,低位补0)
>>右位移 (右移运算是将操作数二进制值逐位右移若干位,右移过程中符号位不变 ,低位溢出并舍弃,并用符号位补溢出的高位[即负数补1,正数补0])
>>> 无符号右位移(无符号右移运算是将操作数所有二进制值逐位右移若干位,包括最高位符号位,也跟着右移,低位溢出并舍弃,高位补0;注意,无符号右移(>>>)中的符号位(最高位)也跟着变)
逻辑运算符:
& 按位与 (与运算是将参与用算两个二进制数进行&用算,如果两个二进制位都是1,则与用算的结果为1,其他全都为0)
| 按位或 (或用算是将参与用算两个二进制数进行 | 用算,如果两个二进制位都是0,则与运算的结果为0,其他全都为1,即只要其中一个数字的二进制位是1,这个二进制位的运算结果就为1)
^ 按位异或(异或^运算是将参与运算的两个二进制进行“异或”运算,如果二进制位相同,则结果为1,否则为0)
~ 取反(取反运算是只针对一个数据进行操作,如果二进制是0,则取反为1,如果二进制是1,则取反为0)
参考:https://blog.csdn.net/black_bird_cn/article/details/80171652