我需要保持对象列表的顺序,因为它可以在我的Web应用程序中随时更改和重新排序。
在我的模型中,我有一个对象数组列表,例如
objectList = [object1, object2, object3, object4]
并且我将属于该实例的每个对象的顺序保存到Map示例中:订单
{
"object1":4,
"object2":2,
"object3":1,
"object4":3
}
因此,我想根据对象Id作为关键字检索到的映射中的值对数组进行排序:
预期结果:
[object3, object2, object4, object1]
我该怎么做?
假设您的对象有一个id为getId()
的getter,那么您可以使用Comparator.comparing()
helper方法,该方法为提供的lambda:创建一个比较器
objectList.sort(Comparator.comparing(o -> yourMap.get(o.getId()));
这实际上与编写自己的Comparator
或编写自己的比较方法相同。
这可能看起来有些过头了,但定义一个新的类可能更自然
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.cailing(new IndexedElement(yourIndex,null((,只需记住覆盖IndexedElement中的equals/hashCode(