欢迎访问悦橙教程(wld5.com),关注java教程。悦橙教程  java问答|  每日更新
页面导航 : > > > 文章正文

关于List的toString方法调用的是否是父类Object的,explise显示是的,但其实不是,是AbstractCollection的,他复写了Object的toString,

来源: javaer 分享于  点击 37991 次 点评:238

关于List的toString方法调用的是否是父类Object的,explise显示是的,但其实不是,是AbstractCollection的,他复写了Object的toString,


今天,我打印了下System.out.println(list),想查看下返回什么?

List<String> list=new ArrayList<String>();

list.add("111");
list.add("222");

System.out.println(s);

打印出来:[111, 222]

追查原因:

1、ArrayList是否重写了Object的toString方法:没有

     List、Collection、Iterable是否重写了该方法,都没有

2、Object的toString方法打印的方法是什么?

     return list.getClass().getName() + "@" + Integer.toHexString(hashCode()) 这个是Object的toString方法的代码

    修改之后打印出来java.util.ArrayList@17c9c2,不符合结果[111, 222]

3、继续查找System.out.println()中的println方法

     println方法

 public void println(Object x) {
        String s = String.valueOf(x);
        synchronized (this) {
            print(s);
            newLine();
        }
    }

String s = String.valueOf(x);

中s的结果是[111, 222]

所以,查看String.valueOf(x)方法

 public static String valueOf(Object obj) {
    return (obj == null) ? "null" : obj.toString();

    }

4、继续跟踪obj.toString()方法,发现调用的是Object的toString()方法

public String toString() {
    return getClass().getName() + "@" + Integer.toHexString(hashCode());
    }

这个方法打印出来的结果[111, 222]跟这个肯定不是一个结果

这个结果跟前面打印出来的结果不符。。。

5、于是郁闷了很久很久。。。。此处省略10000个字。。。发现结果不符。。继续查看

6、终于发现新大陆了,原来list.toString()的toString方法调用的是类java.util.AbstractCollection;中的toString方法

源码如下:

public String toString() {
        Iterator<E> i = iterator();
    if (! i.hasNext())
        return "[]";

    StringBuilder sb = new StringBuilder();
    sb.append('[');
    for (;;) {
        E e = i.next();
        sb.append(e == this ? "(this Collection)" : e);
        if (! i.hasNext())
        return sb.append(']').toString();
        sb.append(", ");
    }
    }

一切都明白了。。




相关文章

    暂无相关文章

用户点评