如何在Java中执行从无符号到有符号的转换?

假设我从输入设备读取了以下字节:“ 6F D4 06

40”。该数字是MilliArcSeconds格式的经度读数。最高位(0x80000000)基本上始终为零,因此该问题被忽略。

我可以轻松地将字节转换为 无符号 整数:1876166208

但是,如何将该无符号值转换为最终形式的31位有符号整数?

到目前为止,我只想出了:

  1. 如果value&0x40000000那么它实际上是负数,需要将其转换
  2. 如果是负数,则剥离最高位,然后对其余位进行一些处理…

因此,我可以判断它是否为负数,但是为了知道负数是什么值,我必须对其余的位做些什么-一个人的称赞?如何在Java中做到这一点?

提出问题的另一种方法是,如何在Java中将无符号整数转换为31位带符号整数?

谢谢!

回答:

答案取决于输入的低31位表示什么。

int input = 0x6FD40640 & 0x7FFFFFFF; //strip top bit; only here for clarity

无符号输入: 0x6FD40640 == 1876166208

回答:

一个 整数是其中-1已设置所有位,和较低的底片数量从那里倒计时。第一位仍然充当符号位。

1000 -> -8

1001 -> -7

...

1110 -> -2

1111 -> -1

0000 -> 0

0001 -> 1

如果低31位代表二进制补码整数,那么我认为您应该能够做到这一点:

input = (input << 1) >> 1;

这是因为Java在内部将整数存储为二进制补码:我们要做的就是向左移然后向右移(带符号),以便选择符号位并将整数从31位变为32位。

回答:

一个 码表示是其中第一位是专用符号位,其余位表示幅度的人。-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左右。

,所以我猜测您的输入格式是二进制补码,因此我的第一个和原始答案是正确的。

以上是 如何在Java中执行从无符号到有符号的转换? 的全部内容, 来源链接: utcz.com/qa/423187.html

回到顶部