当前位置: 首页 > 面试题库 >

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

周和安
2023-03-14
问题内容

假设我从输入设备读取了以下字节:“ 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

二进制补码(期望输出:-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
,所以我猜测您的输入格式是二进制补码,因此我的第一个和原始答案是正确的。



 类似资料:
  • 问题内容: 在C语言中,我可以使用数字做一些技巧: 在Swift中有没有办法做到这一点?请注意,相同的方法无效: 有没有一种方法可以让C的行为在Swift中减法? 谢谢! 问题答案: 所有有符号和无符号整数类型都有一个构造函数,该构造函数从具有相同内存表示形式的有符号(反之亦然)创建无符号数字:

  • 问题内容: 假设我有这个号码。我如何将其称为无符号变量?像C一样 问题答案: 假设 : 您会想到2的补码表示法;和, 通过您 的意思是 32位无符号整数, 那么您只需将其添加为负值即可。 例如,将此应用于-1: 假设1表示您希望将-1视为一个1位的实字符串,而假设2表示您希望其中的32个。 但是,除了你,没人可以说你隐藏的假设是什么。例如,如果考虑到1的补码表示形式,则需要应用前缀运算符。Pyth

  • 我快速浏览了C 03标准,但仍然无法判断这种行为是否有保证: 结果是: VC在32位窗口中给出<code>0xffffffff。但我的假设是,转换可以通过两种方式进行: 1) 8位有符号字符-1首先直接转换为8位无符号值,该值为二进制11111111或十进制255,然后扩展为32位无符号整数,给出255(0xff)。 2)8位有符号字符-1被有符号扩展到32位有符号int,给出0xffffffff

  • 你好,我正在尝试创建一个程序路径并放入注册表文件中,但我一直出错。这是代码: 我得到的错误说 从“char*”到“unsigned char”[-fppermissive]的转换无效 我花了几个小时寻找解决方案,但我找不到。

  • 问题内容: 关于Java支持哪种无符号数据类型,我有些困惑。 我已经读过了,但我不理解它的非常复杂的解释(至少对我而言)。 问题答案: Java仅支持带符号的类型(除外),因为它假定对于初学者来说,一种类型比每种大小都具有两种类型更容易理解。在C语言中,它被认为是错误的根源,因此不包括对无符号类型的支持。 因此设计师选择了四种尺寸 ,8位 ,16位 ,32位 ,64位。 并保持一致性,他们都签署就

  • 编辑3: 编辑2: 像这样创建了图像.... 编辑: 我意识到我试图问的是如何从有符号灰度到无符号灰度,因为我说添加256对我不起作用,而且这似乎仍然会使图像变暗,因为它不会将127个有符号值的值提高到256无符号。(希望我表达得正确。 根据标题,我从缓冲图像中通过 数组的范围从-128到127。问题是,当我试图通过将int[]传递给BuffereImage来基于int[]重建图像时,结果太暗,更