我有一个实体Entity
列表,其中包含字段id
和createdDate
。我想对它们进行如下排序:
id
id
为空,则最近的createdDate
首先我尝试了以下失败的尝试,因为当NullPointerException
为空时,它抛出了id
Comparator comp = Comparator
.nullsFirst(Comparator.comparing(e -> ((Entity) e).getId()))
.thenComparing(e -> ((Entity e).getCreatedDate())
.reversed();
entities.stream().sorted(comp).findFirst();
对于我所看到的,Comparator.nullsFirst
处理实体为空的情况,而不是要比较的字段为空的情况。我该如何处理这种情况?
答案 0 :(得分:5)
我认为您正在寻找这样的比较器:
Comparator<MyClass> comparator = Comparator.comparing(MyClass::getId, Comparator.nullsLast(Comparator.reverseOrder()))
.thenComparing(MyClass::getCreateDate);
要测试的代码:
List<MyClass> list = new ArrayList<>();
list.add(new MyClass(null, LocalDate.now()));
list.add(new MyClass(4L, LocalDate.now()));
list.add(new MyClass(2L, LocalDate.now()));
list.add(new MyClass(4L, LocalDate.now().plusDays(1)));
list.add(new MyClass(null, LocalDate.now().plusDays(1)));
Comparator<MyClass> comparator = Comparator.comparing(MyClass::getId, Comparator.nullsLast(Comparator.reverseOrder()))
.thenComparing(MyClass::getCreateDate);
list.stream().sorted(comparator).forEach(myClass -> System.out.println(myClass.id + " " + myClass.createDate));
输出为:
4 2019-06-14
4 2019-06-15
2 2019-06-14
null 2019-06-14
null 2019-06-15
如果您想首先使用nulls
,只需将nullsLast
更改为nullsFirst
。
答案 1 :(得分:1)
扩展@Mena的评论:
java.util.Collections.sort(entities, new Comparator<Entity>(){
@Override
public int compare(Entity ent1, Entity ent2) {
Object id1=ent1.getId();
Object id2 = ent2.getId();
if (id1!=null && id2!=null)
{
return id2.compareTo(id1);
}
else
{
Date d1 = ent1.getCreatedDate();
Date d2 = ent2.getCreatedDate();
return d2.compareTo(d1);
}
}
});
答案 2 :(得分:1)
使用Object类中的nonNull方法也许可以解决它。
Comparator comp = Comparator
.nullsFirst(Comparator.comparing(e -> nonNull(((Entity) e).getId()))
.thenComparing(e -> ((Entity e).getCreatedDate())
.reversed();
entities.stream().filter(comp).findFirst();
答案 3 :(得分:0)
我不太使用lambda,但是我可以帮助您使用比较器。
Comparator<Entity> cmp = new Comparator<Entity>() {
@Override
public int compare(Entity e1, Entity e2) {
if(e1.id!=null && e2.id!=null){
return e2.id - e1.id;
}
return e1.createdDate - e2.createdDate;
//createdDate should be an Integer field otherwise convert it to integer somehow.
}
};
//To use this comparator
Collections.sort(your_list,cmp);