小编典典
答案取决于输入的低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
,所以我猜测您的输入格式是二进制补码,因此我的第一个和原始答案是正确的。
2020-11-16