Java中的Unsigned Int
问题内容:
我正在尝试实现一个现有的网络协议,该协议大量使用了Java不支持的Unsigned数据类型。我目前对每种数据类型执行的操作是,选择下一个更大的数据类型,以使无符号数字适合正数区域,然后使用字节移位获得所需的效果。由于这很容易出错,并且长期以来无符号,我必须使用比扩展类型重得多的BigInteger,我想知道是否有更好的方法来实现这一点?
问题答案:
根据您的工作,您可以将long视为64位值,将int视为32位值。大多数操作(尤其是readInt / Long writeInt /
Long)都通过忽略符号来实现相同的功能。
您能否举例说明您对这些数字执行的操作,也许我们可以建议如何在不扩展类型的情况下执行相同的操作。
例如,++,-,+,-,*,==,!=,<<都与工作无关,而无论是否使用手势(即给出相同答案)。为>>您可以替代>>>
/,%,>,> =,<,<=和打印函数采用带符号的值,但是您应该能够解决这些问题(如果使用这些)。
例如
long unsignedA =
long unsignedB =
boolean greater = unsignedA + Long.MIN_VALUE > unsignedB + Long.MIN_VALUE
编辑:为什么这样做?部分原因是Java没有上溢/下溢异常。
例如
byte unsignedA = 0;
unsignedA--;
// unsignedA == FF, is this -1 or 255? Java assumes the former but you assume the later
byte unsignedB = unsignedA * unsignedA;
// unsignedB is -1 * -1 = 1 or (byte) (255*255) = (byte) 65525 = 1.