码迷,mamicode.com
首页 > 其他好文 > 详细

println与toString()

时间:2014-10-12 15:57:58      阅读:151      评论:0      收藏:0      [点我收藏+]

标签:style   blog   color   os   ar   java   sp   div   on   

 

  

 

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()

标签:style   blog   color   os   ar   java   sp   div   on   

原文地址:http://www.cnblogs.com/NeilLing/p/4020471.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!