简单分析一下为什么System.out.println(Object x)有时候打印内容,有的时候打印一串地址。内部做了哪些操作,我们如何能够打印出我们想要的?
先来猜测一下,这例子的两个输出分别是什么?
TreeSet<Person> treeSet=new TreeSet<>();
treeSet.add(new Person(10,"name1"));
treeSet.add(new Person(10,"name2"));
System.out.println(treeSet);
TreeSet<String> treeSetS=new TreeSet<>();
treeSetS.add("name1");
treeSetS.add("name2");
System.out.println(treeSetS);
package com.snow;
public class Person implements Comparable{
private int age;
private String name;
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
@Override
public int compareTo(Object o) {
return 1;
}
public Person(int age, String name) {
this.age = age;
this.name = name;
}
}
答案:
[com.snow.Person@60e53b93, com.snow.Person@5e2de80c]
[name1, name2]
分析一下为什么:
首先看一下println方法的定义:
public void println(Object x) {
String s = String.valueOf(x);
synchronized (this) {
print(s);
newLine();
}
}
先是调用了String.valueOf方法,这个valueOf方法如下:
public static String valueOf(Object obj) {
return (obj == null) ? "null" : obj.toString();
}
在valueOf方法里调用了toString方法。所以输出什么其实是toString()方法定义好的。
对于String类型的toString()方法就是直接输出内容,对于自定义的Person类,由于我们没有override toString()方法,在输出时会调用Object的toString()方法。
public String toString() {
return getClass().getName() + "@" + Integer.toHexString(hashCode());
}
为了证实我们的research,我在Person类中override了toString()方法,再来看看输出的是什么?
@Override
public String toString() {
return this.name+"="+this.age;
}
输出:
[name1=10, name2=10]
[name1, name2]
证实了我们想法。
收~