首頁 >Java >java教程 >如何在 Java 中根據另一個列表的順序對一個列表進行排序?

如何在 Java 中根據另一個列表的順序對一個列表進行排序?

Barbara Streisand
Barbara Streisand原創
2024-11-02 15:46:291014瀏覽

How to Sort One List Based on the Order of Another List in Java?

在Java 中根據另一個列表對一個列表進行排序

在Java 中,可以根據另一個列表的順序對一個列表進行排序。當您在一個清單 (listB) 中有特定的項目序列並且您想要重新排列第二個清單 (listA) 以符合該順序時,這可能很有用。

實現此目的的一種方法是使用具有自訂比較器的Collections.sort() 方法如下:

<code class="java">Collections.sort(listToSort, new Comparator<T>() {
    @Override
    public int compare(T o1, T o2) {
        return listWithOrder.indexOf(o1) - listWithOrder.indexOf(o2);
    }
});</code>

這裡,listToSort 表示未排序的列表,listWithOrder 包含所需的列表指令。此比較器根據 listWithOrder 中元素的順序對 listToSort 進行排序。

對於 Java 8 及更高版本,您可以使用 lambda 和 ComparisonInt() 方法來簡化程式碼:

<code class="java">listToSort.sort(Comparator.comparingInt(listWithOrder::indexOf));</code>

以上是如何在 Java 中根據另一個列表的順序對一個列表進行排序?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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