您好,登錄后才能下訂單哦!
這篇文章主要為大家展示了Java中如何替代equals,compareTo和toString,內容簡而易懂,希望大家可以學習一下,學習完之后肯定會有收獲的,下面讓小編帶大家一起來看看吧。
我們都曾在POJO中重寫過equals(),compareTo()和toString()方法。但是另有其他能做到職責分離的更好的方法并帶來更簡潔的代碼。閱讀這篇文章來一探究竟吧!
更簡明的職責——擺脫equals、compareTo和toString方法
你曾經查看過java文檔中的Object類嗎?也許吧。每當你向上追溯繼承樹的時候都會止步于這個類。你會注意到,該類有幾個方法是每一個類都必須繼承的。而你最喜歡重寫的方法可能就是toString(), .equals() and .hashCode() 這三個了。(至于為何總是應該同時重寫后兩個方法,請看Per-Åke Minborg寫的這篇文章:https://minborgsjavapot.blogspot.com/2014/10/new-java-8-object-support-mixin-pattern.html)
但是僅僅有這幾個方法顯然是不夠的。許多人將標準庫中的其他的接口如Comparable和Serializable加以組合。但是這樣真的明智嗎?為什么每個人都很迫切地去自己實現這些方法呢?事實上,當你準備將對象存儲在一些容器中,如HashMap,并且想要控制哈希沖突的時候,實現你自己的.equals()方法和.hashCode()方法確實有它的意義,但實現compareTo()和toString()方法又是為何呢?
本篇文章中我將提出一種使用到Speedment 開源項目上的軟件設計方法,這里的對象的方法被定義為存儲于變量上的方法引用,而不是重寫它們。這樣做確有一些好處:你的POJO將會更短小簡潔,通用的方法可以不需要繼承而進行復用并且你可以因地制宜地使用它們。
原始的代碼
首先我們來看下面的代碼:這里有一個典型的Java類Person。在使用中需要從一個Set中打印出每一個person對象,并且按照姓在前和名在后的順序排列(以防出現兩個相同姓氏的人)。
// Person.java public class Person implements Comparable<Person> { private final String firstname; private final String lastname; public Person(String firstname, String lastname) { this.firstname = firstname; this.lastname = lastname; } public String getFirstname() { return firstname; } public String getLastname() { return lastname; } @Override public int hashCode() { int hash = 7; hash = 83 * hash + Objects.hashCode(this.firstname); hash = 83 * hash + Objects.hashCode(this.lastname); return hash; } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (getClass() != obj.getClass()) return false; final Person other = (Person) obj; if (!Objects.equals(this.firstname, other.firstname)) { return false; } return Objects.equals(this.lastname, other.lastname); } @Override public int compareTo(Person that) { if (this == that) return 0; else if (that == null) return 1; int comparison = this.firstname.compareTo(that.firstname); if (comparison != 0) return comparison; comparison = this.lastname.compareTo(that.lastname); return comparison; } @Override public String toString() { return firstname + " " + lastname; } }
// Main.java public class Main { public static void main(String... args) { final Set people = new HashSet<>(); people.add(new Person("Adam", "Johnsson")); people.add(new Person("Adam", "Samuelsson")); people.add(new Person("Ben", "Carlsson")); people.add(new Person("Ben", "Carlsson")); people.add(new Person("Cecilia", "Adams")); people.stream() .sorted() .forEachOrdered(System.out::println); } }
Output
run:
Adam Johnsson
Adam Samuelsson
Ben Carlsson
Cecilia Adams
BUILD SUCCESSFUL (total time: 0 seconds)
Person
類實現了一些方法來控制輸出。 hashCode()
和equals()
方法確保同一個person對象不會被重復添加到set中。.compareTo()
方法用于排序方法中生成應有的順序。而重寫方法toString()
是在System.out.println()
被調用的時候控制每個Person對象的輸出格式。你認出這種結構了嗎?幾乎任何一個java工程中都會有它。
替代這些代碼
相比于將所有這些方法寫入Person類中,我們可以讓它保持盡量的簡潔,使用方法引用去處理它們。我們可以刪除所有equals(),hashCode(),compareTo()和toString()的樣板式代碼,取而代之的是下面介紹的兩個靜態變量:COMPARATOR
和TO_STRING
。
// Person.java public class Person { private final String firstname; private final String lastname; public Person(String firstname, String lastname) { this.firstname = firstname; this.lastname = lastname; } public String getFirstname() { return firstname; } public String getLastname() { return lastname; } public final static Comparator<Person> COMPARATOR = Comparator.comparing(Person::getFirstname) .thenComparing(Person::getLastname); public final static Function<Person, String> TO_STRING = p -> p.getFirstname() + " " + p.getLastname(); }
// Main.java public class Main { public static void main(String... args) { final Set people = new TreeSet<>(Person.COMPARATOR); people.add(new Person("Adam", "Johnsson")); people.add(new Person("Adam", "Samuelsson")); people.add(new Person("Ben", "Carlsson")); people.add(new Person("Ben", "Carlsson")); people.add(new Person("Cecilia", "Adams")); people.stream() .map(Person.TO_STRING) .forEachOrdered(System.out::println); } }
Output
run:
Adam Johnsson
Adam Samuelsson
Ben Carlsson
Cecilia Adams
BUILD SUCCESSFUL (total time: 0 seconds)
這樣實現的好處是我們可以在不用更改Person類的情況下替換排序策略或打印格式。這將使代碼擁有更強的可維護性和復用性,更不用說更快的編寫速度了。
以上就是關于Java中如何替代equals,compareTo和toString的內容,如果你們有學習到知識或者技能,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。