溢出在以下情况发生 :
当整数的数据大小超出了可以表示的范围,而程序中又没有做数值范围的检查时,这个整型变量所输出的值将发生紊乱,且不是预期的运行结果。在下面的程序范例中,声明了一个整型的数,并把它赋值为整型所可以表示范围的最大值,然后将它分别加 1 和加 2。
范例:
// 整数值如果超出了自己所可以表示范围的最大值,会出现溢出
public class TestJava1
{
public static void main(String args[])
{
int x=java.lang.Integer.MAX_VALUE ;
// 得到整型的最大值07 08
System.out.println("x = "+x);
System.out.println("x+1 = "+(x+1));
System.out.println("x+2 = "+(x+2));
}
}
输出结果:
x = 2147483647
x+1 = -2147483648
x+2 = -2147483647
当最大值加上 1 时,结果反而变成表示范围中最小的值;当最大值加上 2 时,结果变成表示范围中次小的值,这就是数据类型的溢出。读者可以发现,这个情形会出现一个循环,若是想避免这种情况的发生,在程序中就必须加上数值范围的检查功能,或者使用较大的表示范围的数据类型,如长整型。当声明了一整数 i,其表示的范围为-2147483648 ~ 2147483647 之间,当 i 的值设为最大值2147483647,仍在整数的范围内,但是当 x 加 1 或加 2 时,整数 x 的值反而变成-2147483648 和-2147483647,成为可表示范围的最小及次小值。上述的情形就像计数器的内容到最大值时会自动归零一样。而在整数中最小值为-2147483648,所以当整数 x 的值最大时,加上 1 就会变成最小值-2147483648,也就是产生了溢出。为了避免 int 类型的溢出,可以在该表达式中的任一常量后加上大写的“L”,或是在变量前面加上 long,作为强制类型的转换。
下面的这段程序当整型发生溢出之后,用强制类型进行转换
public class TestJava2 //01
{ //02
public static void main(String args[]) //03
{ int x =java.lang.Integer.MAX_VALUE ; //04
System.out.println("x = "+x); //05
System.out.println("x + 1 = "+(x+1));//06
System.out.println("x + 2 = "+(x+2L));//07
System.out.println("x + 3 = "((long)x+3));
} //09
} //10
输出结果:
x = 2147483647
x + 1 = -2147483648
x + 2 = 2147483649
x + 3 = 2147483650
程序说明:
1、 第 4 行声明 int 类型的整数变量 x,并赋值为整数最大值,即 2147483647。
2、 第 5行输出 x 的值,即:2147483647。
3、 第 6行输出 x+1 的值,此时溢出发生,运行结果变成-2147483648。
4、 第 7行输出 x+2 的值,为了避免溢出发生,在表达式的常量部分 2 后加上 L,执行结果变成 2147483649。
5、 第 8 行输出 x+3 的值,为了避免溢出发生,在表达式的整数部分 x 之前加上 long,执行结果变成 2147483650。由上面的程序可知,处理 int 类型的溢出,可以利用强制类型转换方式。但是对于 long 类型的溢出,就没有处理办法了,此时就需要在程序中加上变量值的界限检查,运行的时候不会发生错误。