首页 > 基础资料 博客日记

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

2025-07-22 19:00:03基础资料围观13

本篇文章分享`System.out.println(Object)` 的打印行为详解,对你有帮助的话记得收藏一下,看Java资料网收获更多编程知识

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

文章来源:https://www.cnblogs.com/buguge/p/18999300
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:jacktools123@163.com进行投诉反馈,一经查实,立即删除!

标签:

相关文章

本站推荐

标签云