在java中获得int型数据的最值
int型数据在计算机中占32位,这就决定了int型数据的最大值为:2147483647
,最小值为:-2147483648,大概是21亿,是一个10位数字,如果编程时可能遇到这个数量级的数字时,就要考虑是否会溢出了。
在java中我们通过以下方式直接获得int型数据的最值
public static void main(String[] args) {
int maxint;
int minint;
maxint=Integer.MAX_VALUE;
minint=Integer.MIN_VALUE;
System.out.print("int最大值为:");
System.out.println(maxint);
System.out.print("int最小值为:");
System.out.println(minint);
}
运行结果:
如何在编程时判断有无溢出
当然不可能死记硬背这个范围,在可能溢出的情况下,我们可以通过比较来判断有没有溢出
比如判断俩个int型变量的乘积有没有溢出,我们可以这样写
public static void main(String[] args) {
int a,b;
a=165132215;
b=845132133;
if(a>Integer.MAX_VALUE/b) {
System.out.println("a*b溢出");
}
}
结果得出ab溢出
注:判断条件写为a>Integer.MAX_VALUE/b,
而不是ab>Integer.MAX_VALUE。因为如果ab溢出的话,ab实际的值会变得奇奇怪怪。
总结:
把乘法转化为除法,来避免或判断是否溢出(如上例);
把加法转化为减法,来避免或判断是否溢出(如(a+b)/2的等价a+(b-a)/2)。
(关于加法的转化有一个细节)
如何在运算后溢出的情况下得到想要的结果?
如 double d=1024 * 1024 * 1024 * 1024;
像这个式子,即使d是double型我们也得不到想要的结果,
因为后边是四个int相乘,运算后结果也是int型,再把结果转换为double赋给d。这样就出问题了,4个int型数据相乘,结果也是int,所以直接溢出了。
可以修改为:double d=1024d * 1024 * 1024 * 1024;
这样其中一个数被定义为double型,结果也就存储在double中
也可以改为:double d=1024l * 1024 * 1024 * 1024;表示第一个数是一个长整型数据