覆盖 toString() 可提升对象信息的可读性,便于调试和日志输出。默认实现仅返回类名和哈希码,意义有限,因此需重写该方法以展示关键属性,如 Person{name='Alice', age=30}。推荐使用 IDE 自动生成或 Lombok 的 @ToString 注解来简化编码,确保格式清晰、信息完整,从而提高代码可维护性和开发效率。

在 Java 中,toString() 是 Object 类的一个方法,每个类都默认继承自 Object。默认的 toString() 方法返回的是对象的类名和哈希码的十六进制形式,例如:com.example.Person@2a139a55。这种输出对调试或日志记录帮助有限,因此我们通常会覆盖(重写)toString() 方法,以提供更有意义的对象信息。
为什么要覆盖 toString()
覆盖 toString() 的主要目的是让对象能以更清晰、可读的方式展示其状态。当你打印对象或将其用于字符串拼接时,Java 会自动调用该方法:
- 方便调试:直接查看对象内容,无需逐个打印字段
- 提升日志可读性:日志中输出有意义的信息
- 与其他系统交互:如 JSON 序列化前的调试输出
如何正确覆盖 toString()
在重写 toString() 时,建议包含对象的关键属性,并保持格式清晰。例如:
public class Person {private String name;
private int age;
@Override
public String toString() {
return "Person{" +
"name='" + name + '\'' +
", age=" + age +
'}';
}
}
这样输出结果类似于:Person{name='Alice', age=30},直观明了。
立即学习“Java免费学习笔记(深入)”;
使用 IDE 或 Lombok 简化操作
手动编写 toString() 容易出错且繁琐。可以借助工具快速生成:
- IDEA / Eclipse:右键 -> Generate -> toString(),选择需要包含的字段
- Lombok:添加注解 @ToString,编译时自动生成
public class Person {
private String name;
private int age;
}
使用 Lombok 后,无需写任何方法,就能获得相同的输出效果。
基本上就这些。覆盖 toString() 是一个简单但非常实用的做法,能显著提升代码的可维护性和调试效率。记得在重写时保持信息完整、格式统一。不复杂但容易忽略。











