Java中的溢出短缺

Java中的溢出短缺,第1张

Java中的溢出短缺

发生的事情是您的电话号码四处徘徊。更具体地说,您有一个数字30,000,二进制形式为:

0111 0101 0011 0000

当您将其添加到自身并携带1时,您将获得:

1110 1010 0110 0000

(注意:将二进制数乘以2很容易-只需将所有位向左移动一位即可。)

short是带二进制补码的带符号数字,表示最左边的1实际上是减号;该数字表示-5536。

如果将该数字再次乘以2,则需要两个以上的字节来表示它。由于a中的字节数不超过2个

short
,因此当
int
表达式的结果缩小为a
时,多余的位将被丢弃
short
。做到这一点就足够了,您将用0作为最左边的数字。该数字再次为正。最后,您将再次获得1作为最左边的数字;该数字再次为负。最终,您将所有0都移到了数字中。将任何整数乘以2足够的倍数将始终为0(特别是,如果它是N位数字,则将其乘以2
N倍将始终为0)。

如果不缩小到a

short
,您最终仍然会用完
int
(需要33位或更多位)中的数字-
这将导致多余的数字被丢弃,这是整数溢出。如果其中一个参数为a
long
,则同样的事情也会发生,尽管它需要65+位。



欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/zaji/5478656.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-12-12
下一篇2022-12-12

发表评论

登录后才能评论

评论列表(0条)

    保存