默认的toString()方法返回“类名@哈希码的十六进制形式”,如com.example.Person@6b4c47ba;建议重写toString()以提升调试、日志输出和代码可读性,便于查看对象实际内容,尤其是在集合打印时能清晰展示对象状态,符合开发规范。

Java中每个类都继承自Object类,而toString()是Object类中的一个方法。如果不重写这个方法,调用对象的toString()时会使用默认实现。
默认输出什么?
默认的toString()方法返回一个字符串,格式如下:
类名@哈希码的十六进制形式
例如:com.example.Person@6b4c47ba
立即学习“Java免费学习笔记(深入)”;
其中:
- com.example.Person 是类的全限定名
- 6b4c47ba 是对象哈希码的无符号十六进制表示
为什么建议重写toString?
默认的输出信息对调试和日志记录帮助有限,因为它不展示对象的实际内容。重写toString能带来以下好处:
便于调试和日志输出
打印对象时能看到关键字段值,而不是一串看不懂的内存地址。比如一个Person对象输出Person{name=’张三’, age=25}比Person@6b4c47ba直观得多。
提升代码可读性
在System.out.println、日志框架或集合打印时,自动调用toString,清晰的格式让开发人员快速理解对象状态。
方便集合类输出
当List、map等集合包含对象时,打印集合会逐个调用元素的toString。如果没重写,看到的是一堆类名+哈希码,难以排查问题。
符合开发规范
多数编码规范(如阿里巴巴java开发手册)建议对POJO类重写toString,便于维护和排查问题。
如何正确重写?
可以手动编写,也可以使用ide生成或Lombok注解简化:
- 手动重写:返回包含主要字段的格式化字符串
- 使用@Override注解确保正确覆盖
- 借助Objects.toStringHelper()(guava)或IDE自动生成
- 使用Lombok的@ToString注解减少模板代码
基本上就这些。重写toString是个小动作,但在实际开发中能显著提升开发效率和问题定位速度。


