例如:我输出的是一个对象,却调用到了toString方法
public class TTT {
private String id;
private String name;
public void setId(String id) {
this.id = id;
}
public void setName(String name) {
this.name = name;
}
public String toString() {
return "学号:" + id + "
姓名:" + name;
}
public static void main(String[] args) {
TTT student = new TTT();
student.setId("1");
student.setName("小明");
System.out.println(student);
}
}
首先还是推荐lz看源代码
简单的讲之所以调用了toString()方法,不是什么编译器默认的,而是因为lz你调用的是out.print()方法
仔细看源代码,在PringStream类中,print方法是这样写的
public void print(Object obj) {
write(String.valueOf(obj));
}
此时调用了String的静态方法valueof
这个方法是这样的
public static String valueOf(Object obj) {
return (obj == null) ? "null" : obj.toString();//注意看,这里调用了toString方法
}
而所有的java对象都派生自Object,如果没有对该方法做重写
则会调用super.toString()
Object中这个方法是这样定义的
public String toString() {
return getClass().getName() + "@" + Integer.toHexString(hashCode());
}
所以打印结果为classname+@hashcode
当重写了toString方法后,根据java的动态绑定原理,调用的为当前对象的toString()方法,所以当你重写了student的toString方法后,打印结果不再是ttt@123456,而是
学号:1
姓名:小明
补充一点:
作为比较,当调用print(String s)时,虽然同为对象,但并没有调用toString()方法,打印结果也不是java.lang.String@hashcode了
原文:http://zhidao.baidu.com/link?url=XH5JQIrvRXR0P5GPMjDd2byytZFWne_Ieuvn7gSIW5_c36duEy-3hOuuEN9KN5ZRhqPLntzO7LC9lmU4nJ2MS_