问题原由:
小编在工作上遇到一个问题,在java程序读取流数据之后,通常会以byte[]数组接收数据。在数据传输时,通常会为了减少网络开销而去除实际不用的位,减少用0填充二进制的数据。从而提高性能。但是随之而来的解析上,遇到了一个小问题。就是在java内,如何快速的寻找自己想要的位。
数据模型:
上图中,此次数据接收一共为6个byte长度,其中byte[0]为开始标识,byte[1]到byte[3]为消息内容,byte[4]中的0到5位为状态信息,并且byte[4]中的6到8位为版本信息,最后的byte[5]为结束标识。
模拟数据:
10101010 => 开始位
01101000 =>消息
01101001 =>消息
00100001 =>消息
00100010 =>版本/状态
01010101 => 结束位
那么我们此次只看byte[4]的这八位数据。如何快速的截取出我们想要的数据。小编思路为使用java的位运算方法来提取想要的位数。为了能直观展示给大家看效果和思路,此数据我们以二进制是形式做分析。
1.我们首先将数据用“与运算符”与11100000进行换算,得到数据的前三位。
数据 00100010
计算 11100000
得到 00100000
2.第二步,我们使用“位移运算符”,进行右移5位。得到最终的结果version
00100000 >> 3 = 001
JAVA代码实例:public static void main(String[] args) throws Exception {
byte num = -94; //二进制:00100010
int result = num & 96; //二进制:11100000
result = result >> 5;
System.out.println(result);
}