首頁 >Java >java教程 >為什麼Java沒有SortedList?

為什麼Java沒有SortedList?

Patricia Arquette
Patricia Arquette原創
2024-12-11 20:35:11608瀏覽

Why Doesn't Java Have a SortedList?

為什麼 Java 缺少 SortedList

與 Java Collections 框架中的 SortedSet 和 SortedMap 不同,Java 沒有提供專用的 SortedList。儘管有這樣的遺漏,Java 確實透過 java.util.Collections.sort() 方法提供了排序功能。

遺漏的原因

缺少 SortedList 的原因從列表迭代器的基本性質來看。列表迭代器優先保留元素的插入順序。另一方面,排序可以被視為對資料結構的操作,改變元素順序。

SortedList 的替代品

  1. 排序集與多重集(Bags):

      排序集與多重集(Bags):
  2. SortedSet 在元素插入期間自動排序,無需手動排序。

    TreeMultiset(Multiset 實現)允許重複元素,同時保留排序order.
    Collections.sort():
透過修改List 實例的內部資料結構對List實例進行排序。 接受比較器進行自訂排序,允許區域設定敏感的字串排序,例如。 PriorityQueue:雖然不是SortedList 的直接替代品,但PriorityQueue 提供了某些隊列行為隊列適合用例。 通過PriorityQueue 迭代返回排序後的元素自定義實現:用戶可以透過擴展AbstractList 類別並覆寫add 來建立自己的SortedList和排序方法。 不建議使用此選項,因為它違反了 List 介面約定並且不提供與現有解決方案相比具有顯著優勢。

以上是為什麼Java沒有SortedList?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn