[英]How to sort an ArrayList using a Map key as list object and value as the order?
我需要保持對象列表的順序,因為它可以在我的 web 應用程序中隨時更改和重新排序。
在我的 model 我有一個對象數組列表示例
objectList = [object1, object2, object3, object4]
我將屬於此實例的每個 object 的訂單保存到 Map 示例中: order
{
"object1":4,
"object2":2,
"object3":1,
"object4":3
}
因此,我想根據對象 ID 作為鍵檢索的 map 中的值對數組進行排序:
預期結果:
[object3, object2, object4, object1]
我將如何 go 這樣做?
假設您的對象有一個用於 id getId()
的 getter,那么您可以使用Comparator.comparing()
輔助方法,該方法為提供的 lambda 創建一個比較器:
objectList.sort(Comparator.comparing(o -> yourMap.get(o.getId()));
這實際上與編寫自己的Comparator
或編寫自己的 compare 方法相同。
看起來有些矯枉過正,但定義一個新的 class 可能更自然
class IndexedElement implments Comparable<Integer> {
private final int index;
private final YourObject element;
public IndexedElement(int index, YourObject element) {
this.index = index;
this.element = element;
}
@Override
public int compareTo(Integer o) {
return this.getIndex().compareTo(o.getIndex()) ;
}
}
將這樣的對象存儲在TreeSet<IndexedElement>
中,您可以自動實現排序和檢索(TreeSet.ceiling(new IndexedElement(yourIndex, null)),只需記住覆蓋 IndexedElement 中的 equals/hashCode)
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.