根据您的工作,您可以将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 laterbyte unsignedB = unsignedA * unsignedA;// unsignedB is -1 * -1 = 1 or (byte) (255*255) = (byte) 65525 = 1.
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)