当你看看这个:
public class a
{
public static void main(String[] args)
{
for (int i = 0; i < 100000; i++)
f(i);
}
public static void f(Integer i)
{
System.out.println(i);
}
}
,看看它是什么样子调用javac a.java && javap -c a
后,你会得到
Compiled from "a.java"
public class a {
public a();
Code:
0: aload_0
1: invokespecial #1 // Method java/lang/Object."<init>":()V
4: return
public static void main(java.lang.String[]);
Code:
0: iconst_0
1: istore_1
2: iload_1
3: ldc #2 // int 100000
5: if_icmpge 21
8: iload_1
9: invokestatic #3 // Method java/lang/Integer.valueOf:(I)Ljava/lang/Integer;
12: invokestatic #4 // Method f:(Ljava/lang/Integer;)V
15: iinc 1, 1
18: goto 2
21: return
public static void f(java.lang.Integer);
Code:
0: getstatic #5 // Field java/lang/System.out:Ljava/io/PrintStream;
3: aload_0
4: invokevirtual #6 // Method java/io/PrintStream.println:(Ljava/lang/Object;)V
7: return
}
此字节码告诉我们Integer.valueOf()
被称为(main 9:
),因此没有优化德在这种情况下,在编译级别。然而,正如@Tim B指出的那样,JVM
内发生的事情是另一个无法预测的问题。最好假定最坏的情况 - JVM不会优化它。
嗯,这是我在技术面试中遇到的一个问题,询问的人相当期待具体的答案。我们在谈论HotSpot JVM。我理解你的观点并同意。 – Sebastian