Potrebbe essere utile mostrarti il bytecode. Date un'occhiata al javap
uscita della classe che segue:
> javap -classpath target\test-classes -c RefTest
Compiled from "RefTest.java"
public class RefTest extends java.lang.Object{
public RefTest();
Code:
0: aload_0
1: invokespecial #8; //Method java/lang/Object."<init>":()V
4: return
public static void main(java.lang.String[]);
Code:
0: aconst_null
1: astore_1
2: aconst_null
3: astore_2
4: getstatic #17; //Field java/lang/System.out:Ljava/io/PrintStream;
7: aload_1
8: invokevirtual #23; //Method java/lang/Object.toString:()Ljava/lang/String;
11: invokevirtual #27; //Method java/io/PrintStream.println:(Ljava/lang/String;)V
14: getstatic #17; //Field java/lang/System.out:Ljava/io/PrintStream;
17: aload_2
18: invokevirtual #33; //Method java/io/PrintStream.print:(Ljava/lang/Object;)V
21: return
}
Solo guardando il metodo principale, è possibile vedere le linee di interesse sono dove Code
è 8 e 33.
Codice 8 mostra il bytecode per te chiamando o.toString()
. Qui o
è null
e quindi qualsiasi tentativo di invocazione di un metodo su null
produce un NullPointerException
.
Il codice 18 mostra l'oggetto null
passato come parametro al metodo PrintStream.print()
. Guardando il codice sorgente di questo metodo vi mostrerà il motivo per cui questo non non risultato nella NPE:
public void print(Object obj) {
write(String.valueOf(obj));
}
e String.valueOf()
faremo con null
s:
public static String valueOf(Object obj) {
return (obj == null) ? "null" : obj.toString();
}
Così si può vedere lì è un test lì che si occupa di null
e impedisce un NPE.
fonte
2011-09-10 20:23:27
È [tutto nella documentazione] (http://download.oracle.com/javase/6/docs/api/java/io/PrintStream.html#print%28java.lang.Object%29). –