首页 > 基础资料 博客日记
`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());
}
示例代码演示
- 下面是默认打印方式
// 普通对象(未重写 toString)
Object obj = new Object();
System.out.println(obj); // 输出: java.lang.Object@6d06d69c
- 如果需要友好打印,可以重新 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
- 关于 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组合,来实现程序日志的打印。
日志框架的优势:
- 异步输出:通过AsyncAppender实现非阻塞日志
- 级别控制:动态调整日志级别(TRACE/DEBUG/INFO/WARN/ERROR)
- 性能优化:使用占位符延迟字符串构建
- 格式定制:自定义日志格式(时间戳、线程ID等)
文章来源:https://www.cnblogs.com/buguge/p/18999300
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:jacktools123@163.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:jacktools123@163.com进行投诉反馈,一经查实,立即删除!
标签:
上一篇:Aspose.Cells 企业案例:助力法国能源企业实现能源数据报告Excel自动化
下一篇:没有了
相关文章
最新发布
- `System.out.println(Object)` 的打印行为详解
- Aspose.Cells 企业案例:助力法国能源企业实现能源数据报告Excel自动化
- wso2~分布式集群部署总结
- 剑指offer-13、调整数组顺序使奇数位于偶数前面(一)
- SpringBoot--如何创建自己的自动配置
- char和varchar的区别?VARCHAR(100)和 VARCHAR(10)的区别?Mysql字段类型20连问
- TreeMap集合--底层原理、源码阅读及它在Java集合框架中扮演什么角色?
- 编程研发工作日记
- 敏感词 v0.27.0 新特性之词库独立拆分
- 用户中心——比如:腾讯的QQ账号可以登录到很多应用当中