此代码你用于将字节数组(4个元素,每个元素一个字节,共32位)按照二进制进行拼接,
public static float byte2float(byte[] b, int index) {
int l;
l = b[index + 0];
l &= 0xff;
l |= ((long) b[index + 1] << 8); // 第index+1个元素向前移动八位,并加上前面呀一个元素,并转换为long类型,因为int数值区间可能不够
l &= 0xffff; //截取16位,
l |= ((long) b[index + 2] << 16); //下一个元素向前移动16位,
l &= 0xffffff; //截取24位
l |= ((long) b[index + 3] << 24);
return Float.intBitsToFloat(l);
}注解:
“&=” :位于运算,这里的”&= 0xff “表示与“11111111” 进行位与运算,用于截取后八位的数据;
“|=” :位或运算,这里的”l |= ((long) b[index + 3] << 8);”用来于(long) b[index + 3] << 8进行拼接,( b[index + 3]向前移动8位,后面的8位用l进行填充)
” Float.intBitsToFloat(l)” :次方法返回对应于给定位表示形式的 float 值。根据 IEEE 754 浮点“单一格式”位布局,该参数被视为浮点值表示形式。
https://blog.csdn.net/mhl29/article/details/51406834
https://book.2cto.com/201309/31448.html
后续持续更新