网站首页 全球最实用的IT互联网站!

人工智能P2P分享Wind搜索发布信息网站地图标签大全

当前位置:诺佳网 > 软件工程 > 后端开发 > Java >

`System.out.println(Object)` 的打印行为详解

时间:2025-07-22 18:36

人气:

作者:admin

标签:

导读:System.out.println(Object) 是 Java 中最常用的输出方法之一,它的行为等同于 java.io.PrintStream#println(Object),因为 System.out 是一个 PrintStream 实例。 package java.lang; public...

System.out.println(Object) 是 Java 中最常用的输出方法之一,它的行为等同于 java.io.PrintStream#println(Object),因为 System.out 是一个 PrintStream 实例。

package java.lang;

public final class System {

    /**
     * The "standard" output stream. This stream is already
     * open and ready to accept output data. Typically this stream
     * corresponds to display output or another output destination
     * specified by the host environment or user.
     * <p>
     * For simple stand-alone Java applications, a typical way to write
     * a line of output data is:
     * <blockquote><pre>
     *     System.out.println(data)
     * </pre></blockquote>
     * <p>
     * See the <code>println</code> methods in class <code>PrintStream</code>.
     *
     * @see     java.io.PrintStream#println()
     * @see     java.io.PrintStream#println(boolean)
     * @see     java.io.PrintStream#println(char)
     * @see     java.io.PrintStream#println(char[])
     * @see     java.io.PrintStream#println(double)
     * @see     java.io.PrintStream#println(float)
     * @see     java.io.PrintStream#println(int)
     * @see     java.io.PrintStream#println(long)
     * @see     java.io.PrintStream#println(java.lang.Object)
     * @see     java.io.PrintStream#println(java.lang.String)
     */
    public final static PrintStream out = null;
}

java.io.PrintStream#println(Object) 方法会打印对象的 字符串表示形式,其行为由 Java 语言规范定义,具体实现如下:

// class java.io.PrintStream

public void println(Object x) {
    String s = String.valueOf(x); // 关键转换
    synchronized (this) {
        print(s);
        newLine(); // 添加换行符
    }
}

其中,java.lang.String#valueOf(Object) 描述了对象转字符串的机制。

// class java.lang.String

public static String valueOf(Object obj) {
    return (obj == null) ? "null" : obj.toString();
}

继续来看Object.toString方法,该方法返回一个类名@十六进制哈希码串。见如下java源码:

// class java.lang.Object

/**
 * Returns a string representation of the object. In general, the
 * {@code toString} method returns a string that
 * "textually represents" this object. The result should
 * be a concise but informative representation that is easy for a
 * person to read.
 * It is recommended that all subclasses override this method.
 * <p>
 * The {@code toString} method for class {@code Object}
 * returns a string consisting of the name of the class of which the
 * object is an instance, the at-sign character `{@code @}', and
 * the unsigned hexadecimal representation of the hash code of the
 * object. In other words, this method returns a string equal to the
 * value of:
 * <blockquote>
 * <pre>
 * getClass().getName() + '@' + Integer.toHexString(hashCode())
 * </pre></blockquote>
 *
 * @return  a string representation of the object.
 */
public String toString() {
    return getClass().getName() + "@" + Integer.toHexString(hashCode());
}

示例代码演示

  1. 下面是默认打印方式
// 普通对象(未重写 toString)
Object obj = new Object();
System.out.println(obj);   // 输出: java.lang.Object@6d06d69c
  1. 如果需要友好打印,可以重新 toString 方法
// 重写 toString 的对象
class Person {
    String name;
    Person(String name) { this.name = name; }
    @Override
    public String toString() { return "Person: " + name; }
}

System.out.println(new Person("Alice")); // 输出: Person: Alice
  1. 关于 lombok的 @ToString 注解

lombok工具会为class类生成 toString 方法。见下方示例:

@ToString
public class Person {
    int age;
    String name;
    
    Person(String name) { this.name = name; }
}

// 上面class经过IDE build以后,会生成如下代码中的 toString方法

public class Person {
    int age;
    String name;

    Person(String name) {
        this.name = name;
    }

    public String toString() {
        return "Person(age=" + this.age + ", name=" + this.name + ")";
    }
}




anyway,生产环境要严谨使用System.out.println来打印对象,PrintStream是同步的,会影响程序性能,尤其是多线程环境下会成为性能瓶颈。相比之下,我们借助更具优势的日志框架,例如SLF4J+Logback组合,来实现程序日志的打印。

日志框架的优势:

  1. 异步输出:通过AsyncAppender实现非阻塞日志
  2. 级别控制:动态调整日志级别(TRACE/DEBUG/INFO/WARN/ERROR)
  3. 性能优化:使用占位符延迟字符串构建
  4. 格式定制:自定义日志格式(时间戳、线程ID等)

当看到一些不好的代码时,会发现我还算优秀;当看到优秀的代码时,也才意识到持续学习的重要!--buguge
本文来自博客园,转载请注明原文链接:https://www.cnblogs.com/buguge/p/18999300


温馨提示:以上内容整理于网络,仅供参考,如果对您有帮助,留下您的阅读感言吧!
相关阅读
本类排行
相关标签
本类推荐

CPU | 内存 | 硬盘 | 显卡 | 显示器 | 主板 | 电源 | 键鼠 | 网站地图

Copyright © 2025-2035 诺佳网 版权所有 备案号:赣ICP备2025066733号
本站资料均来源互联网收集整理,作品版权归作者所有,如果侵犯了您的版权,请跟我们联系。

关注微信