我继承了一些代码而无法弄清楚它的一部分:
byte[] b = new byte[4] { 3, 2, 5, 7 };
int c = (b[0] & 0x7f) << 24 | b[1] << 16 | b[2] << 8 | b[3];
谁能告诉我们这里发生了什么?
答案 0 :(得分:20)
基本上它使用big-endian conversion将4字节数组的低31位转换为整数。
因此{0,0,0,1}的字节数组将转换为1; {0,0,1,0}的字节数组将转换为256等。
它通过按位运算符的混合来实现:
答案 1 :(得分:5)
没有在一分钟内完成数学运算所以...为了好玩:
[显示操作顺序的额外括号]
((b[0] & 0x7f) << 24) | (b[1] << 16) | (b[2] << 8) | b[3]
(b[0] & 0x7f) << 24 = 11 0000 0000 0000 0000 0000 0000
b[1] << 16 = . . . . . . . . . . 10 0000 0000 0000 0000
b[2] << 8 = . . . . . . . . . . . . . . . 101 0000 0000
b[3] = . . . . . . . . . . . . . . . 0111
现在或者这些在一起,你得到了
0011 0000 0010 0000 0101 0000 0111 = 50,464,007