答案取决于输入的低 31 位要表示的内容。
int input = 0x6FD40640 & 0x7FFFFFFF; //strip top bit; only here for clarity
无符号输入:0x6FD40640 == 1876166208
二进制补码(所需输出:-271317440)
二进制补码整数是其中 -1 设置了所有位,并且较低的负数从那里向下计数的整数。第一位仍然充当符号位。
1000 -> -8
1001 -> -7
...
1110 -> -2
1111 -> -1
0000 -> 0
0001 -> 1
如果低 31 位代表一个二进制补码整数,那么我认为你应该能够做到这一点:
input = (input << 1) >> 1;
这是因为 Java 在内部将整数存储在二进制补码中:我们所做的只是左移然后右移(有符号),以便拾取符号位并且整数从 31 位变为 32 位。
一个补码(所需输出:-802424384)
一个补码数表示是第一位是专用符号位,其余位表示幅度。-100 的低位将与 100 的低位相同:
1111 -> -7
1110 -> -6
...
1001 -> -1
1000 -> -0 (anomoly)
0000 -> 0
0001 -> 1
如果低 31 位表示一个补码整数(即,一个符号位后跟 30 位表示无符号幅度),那么您需要将其转换为二进制补码,以便 Java 正确提取该值。为此,您只需提取低 30 位并乘以 -1:
if ( input & 0x40000000 ) {
input = (input & 0x3FFFFFFF) * -1;
}
您在问题的评论中说,在转换为度数(除以 3600000)后,您会得到 -75.36 左右。 当我将 -271317440 除以 3600000 时,我得到 -75.36595555555556,所以我猜你的输入格式是二进制补码,所以我的第一个和原始答案是正确的。