Я играл с javap и некоторым очень простым кодом, и это подняло - надеюсь, простой - вопрос.
вот код сначала:
public class Main {
public static void main(String[] args) throws Exception {
System.out.println(m1());
System.out.println(m2());
}
private static String m1() {
return new String("foobar");
}
private static String m2() {
String str = "foobar";
return new String(str);
}
}
Теперь я скомпилировал код и посмотрел на результат (пока опуская -verbose).
$ javap -c Main.class
Compiled from "Main.java"
public class Main {
public Main();
Code:
0: aload_0
1: invokespecial #1 // Method java/lang/Object."<init>":()V
4: return
public static void main(java.lang.String[]) throws java.lang.Exception;
Code:
0: getstatic #2 // Field java/lang/System.out:Ljava/io/PrintStream;
3: invokestatic #3 // Method m1:()Ljava/lang/String;
6: invokevirtual #4 // Method java/io/PrintStream.println:(Ljava/lang/String;)V
9: getstatic #2 // Field java/lang/System.out:Ljava/io/PrintStream;
12: invokestatic #5 // Method m2:()Ljava/lang/String;
15: invokevirtual #4 // Method java/io/PrintStream.println:(Ljava/lang/String;)V
18: return
}
Теперь все это имеет смысл, и я понимаю разные байтовые коды, но вопросы, которые пришли мне в голову, таковы:
- Я вижу «m1» и «m2», упомянутые в вызовах invokestatic, поэтому они каким-то образом вызываются, но я не вижу их фактических выходных данных байт-кода в вызове javap!
- Теперь они встроены или просто не отображаются? И если да, то почему?
Опять же, этот вопрос представляет собой чистый интерес к тому, как javac обрабатывает этот материал внутри. Спасибо!