前言:
之前对Java位运算符使用一直云里雾里的,最近正好用到了,详细的整理下,以便日后回顾
位运算符主要针对二进制进行位运算,位运算符主要分为与(&)、非(~)、或(|)、异或(^) 按位左移运算符(<<)按位右移运算符(>>) 按位右移补零操作符 (>>>)
下面实例主要使用 与(&) 、或(|)、按位左移运算符(<<)
与运算符(&)
使用方法:如果相对应位都是1,则结果为1,否则为0
例:60 & 13
60的二进制为 0011 1100
&
13的二进制为 0000 1101
结果 0000 1100
0001 0100 的十进制为12,所以最终结果为12
或运算符(|)
使用方法:如果相对应位都是 0,则结果为 0,否则为 1
例:60 | 13
60的二进制为 0011 1100
|
13的二进制为 0000 1101
结果 0011 1101
0011 1101 的十进制为61,所以最终结果为61
异或运算符(^)
使用方法:如果相对应位值相同,则结果为0,否则为1
例:60 | 13
60的二进制为 0011 1100
^
13的二进制为 0000 1101
结果 0011 0001
0011 0001 的十进制为49,所以最终结果为49
非运算符(~)
使用方法:按位取反运算符翻转操作数的每一位,即0变成1,1变成0。
例 ~60
60的二进制为 0011 1100
~60的二进制为 1100 0011
1100 0011的十进制为-61
按位左移运算符(<<)
左操作数按位左移右操作数指定的位数。
例:60<<2
60的二进制为 0011 1100 <<2
即 0011中的 11向左移动两位后面也跟着移动 后位补0
结果为 1111 0000
1111 0000 的十进制为240
按位右移运算符(>>)
左操作数按位右移右操作数指定的位数。
例:60 >> 2
60的二进制为 0011 1100 >>2
结果为1111
1111的十进制为 15
按位右移补零操作符 (>>>)
左操作数的值按右操作数指定的位数右移,移动得到的空位以零填充。
例:60 >>>2
60的二进制为 0011 1100 >>>2
结果为0000 1111
0000 1111的十进制为 15
实例操作
把byte[]数组中的两个字节转换为一个short类型数值
byte[]{-22,-2}
byte[]数组中有两个byte分别为-22 ,2 现在要合并这两个数值
方法如下
public short getShort1(byte a,byteb) {
return (short) ((a & 0xFF)| (b << 8));
}
a & 0xFF的含义是想保持二进制补码的一致性。
因为如果a是正值没什么影响,如果a是负值,则会出现问题,在计算机中负值是以其正值的补码存在的
& 0xFF的意义为 除去低8位,其他位取0,这样就能保证二进制补码的一致性
这里就不详细解释了,具体请参考文章Java中&0xFF是什么意思?计算机的原码、补码和反码_xmc281141947的博客-CSDN博客_0xff是什么意思
b<<8的意义在于在二进制中前边是高位,后边是低位 因为 short是16位,所以高位在前,b要左移8位,然后在进行或(|)操作
至此,转换就以完成,感谢各位小伙伴耐心看完这篇文章,希望大家都能早日达成自己的目标,加油,奥利给!!!