关于List的toString方法调用的是否是父类Object的,explise显示是的,但其实不是,是AbstractCollection的,他复写了Object的toString,
关于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)方法
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(", ");
}
}
一切都明白了。。
相关文章
- 暂无相关文章
用户点评