Pet*_*Mmm 4 java byte bit-manipulation bitwise-operators
我有这个代码
byte[] b = new byte[]{-33,-4,20,30};
System.err.println(Arrays.toString(b));
int x = (b[0] << 24) + (b[1] << 16) + (b[2] << 8) + b[3];
b = new byte[]{(byte)(x >> 24), (byte)(x >> 16), (byte)(x >> 8), (byte)(x)};
System.err.println(Arrays.toString(b));
Run Code Online (Sandbox Code Playgroud)
输出:
[-33, -4, 20, 30]
[-34, -4, 20, 30]
Run Code Online (Sandbox Code Playgroud)
我无法弄清楚为什么这个操作不是反转的.
您的问题是不需要的标志扩展.
具体来说,b[1]是-4,或者0xfc是符号扩展0xfffffffc然后左移到0xfffc0000.这具有将最高有效字节递减1的效果.
尝试:
int x = ((b[0] & 0xff) << 24) +
((b[1] & 0xff) << 16) +
((b[2] & 0xff) << 8) +
(b[3] & 0xff);
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
2223 次 |
| 最近记录: |