• 博客园logo
  • 会员
  • 周边
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录

Neil_Ling

  • 博客园
  • 联系
  • 订阅
  • 管理

公告

View Post

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了吧。

posted on 2014-10-12 13:42  Neil_Ling  阅读(572)  评论(0)    收藏  举报

刷新页面返回顶部
 
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3