首页 > 代码库 > println与toString()

println与toString()

 

  

 

public class Test{        public static void main(String[] args) {        Mankind mk=new Mankind();        System.out.println(mk);//打印50        System.out.println(".......................");        Person per=mk.new Person();        per.speak();        System.out.println(mk.toString());    }}class Mankind{    private int old=50;    public String toString() {        // TODO Auto-generated method stub        return "ok";    }    class Person {      void speak() {        // TODO Auto-generated method stub          System.out.println("old="+new Mankind());          System.out.println("old="+Mankind.this);               }            }}

下面是解释:

1、System.out.println(center.toString())这句对应的源码:

public void println(String x) {
    synchronized (this) {
        print(x); // 打印x
        newLine(); // 换行
 }
}
这能看懂吧,直接输出了传进来的参数x(center.toString())
2、System.out.println(center)这句对应的源码:
public void println(Object x) {
        String s = String.valueOf(x); // x对象转换为String
        synchronized (this) {
            print(s);
            newLine();
        }
    }
 主要看String s = String.valueOf(x);这句,然后再看看是怎么把对象x转换为String的,
 String.valueOf(x)对应的源码:
 public static String valueOf(Object obj) {
    return (obj == null) ? "null" : obj.toString();
    }
  这下看到了吧,把刚才那x(也就是你的center)转换为String是调用了obj.toString()得到
  的。
  所以"直接输出对象时,会默认调用对象toString()方法"
  3、我把 toString 改成 tostring 其变输出 ClassRoom@7150bd4d
  这里就直接调用到Object.toString()方法了,看看这方法的源码:
  public String toString() {
    return getClass().getName() + "@" + Integer.toHexString(hashCode());
    }
    这下知道为啥输出ClassRoom@7150bd4d了吧。

println与toString()