首頁 > Java > java教程 > Java 比較器與可比較指南及範例

Java 比較器與可比較指南及範例

Susan Sarandon
發布: 2025-01-10 12:29:42
原創
243 人瀏覽過

Java Comparator vs Comparable Guide with Example

想像一下您是 Java 程式設計師,您的任務是排序。好吧,你很幸運,因為 Java 沒有一個而是兩個排序超級英雄準備好拯救世界:ComparableComparator。但是,等等,這兩位英雄相處得不太好——他們更像是亦敵亦友。那麼,當分類惡棍進攻時,你應該呼叫哪一個呢?讓我們來分解一下。

類似: 獅子狼

見Comparable介面。 就像一位總是堅持用自己的方式做事的英雄。當你實作 Comparable 時,你是在說:「我知道如何對自己進行排序。」是的,實作 Comparable 的物件有自己的內建排序規則,有點像是有自己的排序 GPS。交易如下:

  • 一招小馬:你只能有一種排序方式。例如,如果您是 Person 類,而您決定按年齡排序,那麼除非您更改程式碼,否則您將陷入困境。這就像告訴每個人,「對不起,大家,我現在是一個『按年齡排序』的人了。處理掉它!」
  • 自然順序:您可以透過重寫compareTo() 方法來定義自然順序。這就像在說:「這是我的預設排序模式。你要么喜歡它,要么,好吧,太糟糕了!」

您需要一個編碼範例嗎?

public class Person implements Comparable<Person> {
    private String name;
    private int age;

    *// Implement compareTo*
    public int compareTo(Person other) {
        return        Integer.compare(this.age, other.age);
}
登入後複製

優點

  • 簡單。只需在類別上呼叫compareTo() 即可完成。
  • 當您有預設的排序方式並且不需要任何花哨的東西時,這很好。

缺點

  • 固執!您只能獲得一種排序行為。想要按其他內容(例如名稱)排序?太可惜了!

比較器:靈活的夥伴?

現在進入比較器——這個很酷、悠閒的伙伴,非常靈活。如果說比較者是獨狼,那麼比較者就是變色龍。它就像是排序的瑞士軍刀。不喜歡預設順序?沒問題,比較器可以讓您按照自己喜歡的方式排序,而無需更改類別本身!

  • 多種排序選項:您可以為不同的排序規則建立不同的比較器-年齡、姓名、身高等等!這就像有一個可以根據情況需要改變形狀的助手。您今天想按名字排序嗎?完畢!明天您想按身高排序嗎?簡單易行!
public class Person {
    private String name;
    private int age;

    *// Comparator for sorting by name*
    public static Comparator<Person> nameComparator = new Comparator<Person>() {
        public int compare(Person p1, Person p2) {
            return p1.name.compareTo(p2.name);
        }
    };

    *// Comparator for sorting by age*
    public static Comparator<Person> ageComparator = new Comparator<Person>() {
        public int compare(Person p1, Person p2) {
            return Integer.compare(p1.age, p2.age);
   }
  };
}
登入後複製

優點

  • 超靈活。根據需要建立多種不同的排序策略。按年齡、姓名、身高排序,無論您喜歡什麼!

  • 你不必搞亂原來的類別。想要以完全不同的方式對物件進行排序而不觸及來源嗎?比較器為您提供支援。

缺點

  • 比 Comparable 更詳細一些。您必須為每個新的排序規則編寫一個單獨的比較器。

對峙:可比較者與比較者

讓我們看看這兩個人在正面交鋒的表現如何:

特徵 可比較? 比較器?

  • 排序方法 物件對自身進行排序(僅一種方式) 單獨的排序規則(多種方式) **在哪裡實作 類別本身內部 類別外部(通常在單獨的比較器中)。
  • 彈性 一種排序方式 無限排序方式
  • 易於使用 單一排序規則更簡單 更適合複雜/多重排序。
  • 修改現有類別? 是的,您修改類別本身不,您保持類別不變

那麼,誰贏了? ?

這是平局! ?

  • 如果您正在處理具有清晰、自然的排序方式的對象,而這種排序方法就是您所需要的,那麼 Comparable 就是您的首選。這是經典的選擇,就像黑色 T 卹一樣,非常實用。

  • 但是,如果您的排序需求稍微複雜一點(您需要處理多個排序規則),或者您不想弄亂原始的類代碼,那麼 Comparator 就是您靈活、時尚的助手。就像戴上霓虹太陽眼鏡——更多選擇,更多樂趣!

最後的想法?

所以你就有了! Comparable 是您預設的一體化排序解決方案,而 Comparator 是您在事情變得有點瘋狂時調用的適應性強的多用途助手。每個人都有自己的優點和缺點,所以在選擇你的排序英雄之前請考慮一下手頭上的任務。

無論您選擇哪一個,Java 中的排序從未如此酷。 ?

以上是Java 比較器與可比較指南及範例的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:dev.to
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板