容易忽视的toString方法

王朝java/jsp·作者佚名  2006-01-09
宽屏版  字体: |||超大  

先看一段程序

/*

* Created on 2005-2-24

*/

/**

* @author snowway

*/

public class A{

private String id;

public String toString(){

return this.id;

}

public static void main(String[] args){

System.out.println(new A());

}

}

原来我想当然以为会打印null,可运行结果是:

Exception in thread "main" java.lang.NullPointerException

at java.io.Writer.write(Writer.java:126)

at java.io.PrintStream.write(PrintStream.java:457)

at java.io.PrintStream.print(PrintStream.java:616)

at java.io.PrintStream.println(PrintStream.java:753)

at A.main(A.java:17)

仔细debug后才知道流程是这样的:

首先调用PrintStream.println(Object)方法,println(Object)调用PrintStream.print(Object)方法,这个方法使用了String.valueOf(Object)来

获取对象的字符串输出,我们看看String.valueOf(Object obj)源码:

public static String valueOf(Object obj) {

return (obj == null) ? "null" : obj.toString();

}

没有问题,由于我们传递的new A()!=null,所以调用new A().toString(),那么此时toString返回的是this.id,很显然是null,

最后println调用了write(str, 0, str.length());呵呵,问题出来了,str==null,那么str.length显然是要抛出NPE的。

给我的教训是:千万不要让类的toString方法返回null!

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
© 2005- 王朝网络 版权所有