// res[0] = (byte) (value & 0xFF);
// // 80 3A 0B 2F
// // 1000 0000 0011 1010 0000 1011 0010 1111
// // & 0000 0000 0000 0000 0000 0000 1111 1111
// res[1] = (byte) ((value >> 8) & 0xFF);
// res[2] = (byte) ((value >> 16) & 0xFF);
// res[3] = (byte) ((value >> 24) & 0xFF);
主要思想是利用按位与运算,以及右移操作,以此取出int数据中的每位数据并赋值。
public static byte[] intToBytes(int value) {
byte[] res = new byte[4];
for(int i = 0; i < 4; ++i) {
res[i] = (byte) ((value >> (i * 8)) & 0xFF);
}
return res;
}
最后的函数如上。
接着是字节数组转为基础数据类型:
// 当执行:res |= bytes[3];时,会进行自动类型转换!
// 也就是说,bytes[3]的1000 0000,会转换为:
// 1111 1111 1111 1111 1111 1111 1000 0000
// 0000 0000 0000 0000 0000 0000 1000 0000
// 将上述结果左移8位,得到:
// 0000 0000 0000 0000 1000 0000 0000 0000 | res
// 如果bytes[2]的最高一位为0,那么,不会出现问题,但是,如果bytes[2]的
// 最高一位为1,那么,会形成:
// 0000 0000 0000 0000 1000 0000 0000 0000
// 1111 1111 1111 1111 1111 1111 1010 0101 (这里假设bytes[2]为1010 0101)
// 所以,正确的做法是:
// res |= (bytes[i] & 0xFF)
主要思想是依据存储顺序,字节数组中高位应该先赋值给int类型中的低字节,再通过将int左移操作将其一步步挪到高位上,那么将例如int类型的4字节,低字节|(按位或)字节数组中高字节即可。
注:1.最开始将res进行左移,因为都是0,为了方便之后每次都要左移,没有影响。
2.当取出字节数组中的一个元素并将其和int按位或时,该8位二进制会被自动补全为4*8=32位二进制,而补的是符号位,固需要考虑符号位为1时,防止数据出错,固需要额外一步和0xFF按位与,只取出最低位即可。
最后代码:
public static int bytesToInt(byte[] bytes) {
int res = 0;
for (int i = 0; i < 4; i++) {
res <<= 8;
res |= (bytes[4 - i - 1] & 0xFF);
}
return res;
}