Java溢出和下溢

溢出

当我们将这样的值分配给一个大于最大允许值的变量时,就会发生溢出。

下溢

当我们将这样的值赋给小于最小允许值的变量时,就会发生下溢。

如果发生上溢或下溢,JVM不会引发任何异常,它只是更改该值。它的程序员负责检查上溢/下溢情况的可能性并采取相应措施。 

示例(溢出)

考虑int变量的情况,它是32位,并且任何大于Integer.MAX_VALUE(2147483647)的值都将被翻转。例如,Integer.MAX_VALUE + 1返回-2147483648(Integer.MIN_VALUE)。

由于Java中int数据类型为32位,因此超过32位的任何值都会被翻转。用数字表示,这意味着在Integer.MAX_VALUE(2147483647)上增加1后,返回值将为-2147483648。实际上,您无需记住这些值,可以使用常量Integer.MIN_VALUE和Integer.MAX_VALUE。

整数下溢

下溢与上溢相反。在发生溢出的情况下达到上限,而在发生下溢的情况下达到下限。因此,从Integer.MIN_VALUE减1后,我们达到Integer.MAX_VALUE。在这里,我们从int的最小值过渡到了最大值。

对于基于非整数的数据类型,上溢和下溢导致INFINITY和ZERO值。