Java

本类阅读TOP10

·使用MyEclipse开发Struts框架的Hello World!(录像1)
·hibernate配置笔记
·AOP编程入门--Java篇
·linux下Tomcat 5.0.20 与 Apache 2 安装/集成/配置
·在win2003下整合了整合Tomcat5.5+ apache_2.0.53+ mod_jk_2.0.47.dll
·构建Linux下IDE环境--Eclipse篇
·Jsp 连接 mySQL、Oracle 数据库备忘(Windows平台)
·ASP、JSP、PHP 三种技术比较
·Tomcat5.5.9的安装配置
·AWT GUI 设计笔记(二)

分类导航
VC语言Delphi
VB语言ASP
PerlJava
Script数据库
其他语言游戏开发
文件格式网站制作
软件工程.NET开发
容易忽视的toString方法

作者:未知 来源:月光软件站 加入时间:2005-2-28 月光软件站

先看一段程序
/*
 * 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!

 




相关文章

相关软件