我在Java中使用数字转换和强制转换进行了一些测试,我发现了这种奇怪的行为(对我而言)
class Test {
public static void main(String[] args) {
//int y = 100000000000000; //does not compile
int x = 100000 * 1000000000; //compile (why?)
System.out.println(x); //x is 276447232
}
}
基本上x和y应该是相同的数字:为什么要编译?
答案 0 :(得分:7)
在Java中未检测到整数溢出,这就是乘法工作正常的原因。但是,您所说的文字太大,因此是编译错误。
我猜绝大多数Java编译器会在编译时预先计算该值,这是JLS不需要的。因此它不会是一个错误,因为不同的编译器可能会编译一段代码或产生错误 - 这是不太好的。
Sun Java编译器实际执行计算,因为反汇编显示:
Compiled from "x.java"
class x extends java.lang.Object{
x();
Code:
0: aload_0
1: invokespecial #1; //Method java/lang/Object."<init>":()V
4: return
public static void main(java.lang.String[]);
Code:
0: ldc #2; //int 276447232
2: istore_1
3: getstatic #3; //Field java/lang/System.out:Ljava/io/PrintStream;
6: iload_1
7: invokevirtual #4; //Method java/io/PrintStream.println:(I)V
10: return
这里要注意的重要一点是,对于所有意图和目的,结果必须与在运行时计算的结果相同。因此,此处不会发生编译器错误。
答案 1 :(得分:0)
Java处理溢出整数而不是异常,而是翻转到负值并继续向上。
举个例子,这是代码片段:
int x = Integer.MAX_VALUE + 1;
System.out.println(x);
Java尽可能地处理它。该片段输出:
-2147483648
Integer.MIN_VALUE的值是多少。当你处理真正的大数字时,你必须要小心。这就是为什么Java有一个BigInteger
类来处理超出整数限制的任意大数。