每個Java工程師都知道toString方法的存在,它是Object類提供的方法,並且所有的Java類都繼承自該類。toString方法的作用是返回該對象的字符串表示。這個方法在debug過程中是非常有用的,開發人員可以直接通過輸出對象的toString方法來看到它的值。本文將探討以toString為中心的Java工程師。
一、toString方法的重寫
所有的Java類都有自己的toString方法,但是默認的實現可能並不是很適合我們的需求。開發人員可以通過重寫toString方法來改變打印出對象的字符串表示。一般而言,我們使用toString打印出的字符串應該是對象屬性的一個簡潔的總結。一些注意事項包括:
- toString方法必須是public訪問級別
- toString方法不能修改對象狀態
- toString方法中應該打印出所有的非-transient屬性
- toString方法中應該使用String.format代替字符串連接符
例如,我們有一個Person類,定義如下:
public class Person { private String name; private int age; public Person(String name, int age) { this.name = name; this.age = age; } public String getName() { return name; } public void setName(String name) { this.name = name; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } }
默認情況下,使用System.out.println(person)打印出的結果是:Person@106d69c。但是,如果我們在Person類中重寫toString方法如下:
@Override public String toString() { return String.format("%s (age %d)", name, age); }
將會輸出更有意義的字符串:John Doe (age 30)。
二、利用toString做Java對象的打印輸出
我們在debug過程中經常需要查看Java對象的狀態,這個時候我們就可以用到toString方法。但是,如果我們要打印出多個對象的信息,每次都手動來調用toString方法輸出會很繁瑣。Java提供了一種更加簡便的方式來實現對象的打印輸出,就是使用Arrays類的toString方法。
假設我們有一個Student類,定義如下:
public class Student { private int id; private String name; private String major; public Student(int id, String name, String major) { this.id = id; this.name = name; this.major = major; } public int getId() { return id; } public void setId(int id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public String getMajor() { return major; } public void setMajor(String major) { this.major = major; } @Override public String toString() { return String.format("Student [id=%d, name=%s, major=%s]", id, name, major); } }
如果我們有一個存儲多個學生對象的數組,我們可以使用Arrays類的toString方法直接輸出這個數組的信息,如下所示:
Student[] students = new Student[3]; students[0] = new Student(1001, "Mary", "Computer Science"); students[1] = new Student(1002, "John", "Mathematics"); students[2] = new Student(1003, "Simon", "Physics"); System.out.println(Arrays.toString(students));
輸出結果如下:
[Student [id=1001, name=Mary, major=Computer Science], Student [id=1002, name=John, major=Mathematics], Student [id=1003, name=Simon, major=Physics]]
三、利用toString進行日誌記錄
在Web開發領域中,指南針的Java工程師需要寫日誌記錄器是常見的需求。使用日誌記錄器會讓代碼更具可操作性,而且能夠提供額外的信息。通過toString可以讓日誌的記錄變得更加簡潔和易讀。還是以Student類為例,我們可以使用以下代碼記錄學生信息的日誌:
import org.slf4j.Logger; import org.slf4j.LoggerFactory; public class Student { private static final Logger LOGGER = LoggerFactory.getLogger(Student.class); private int id; private String name; private String major; public Student(int id, String name, String major) { this.id = id; this.name = name; this.major = major; LOGGER.info("Creating new Student: {}", this); } @Override public String toString() { return String.format("Student [id=%d, name=%s, major=%s]", id, name, major); } }
在構造器中,我們可以通過使用{}來引用對象本身,這樣就能夠輸出對象的信息。日誌記錄器會自動調用toString方法。通過這樣的方式,我們可以獲得更好的日誌信息,同時,也可以更好地跟蹤問題。
四、結語
本文探討了以toString為中心的Java工程師。我們可以利用toString重寫,用Arrays類的toString方法進行Java對象的打印輸出,使用toString進行日誌記錄等等。這些技巧可以讓日常開發變得更加輕鬆和高效。
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/199855.html