问题
我正在使用java lambda对列表进行排序。
我怎样才能以相反的方式对它进行排序?
我看到了这个447731700,但我想使用java 8 lambda。
这是我的代码(我使用* -1)作为黑客
Arrays.asList(files).stream()
.filter(file -> isNameLikeBaseLine(file, baseLineFile.getName()))
.sorted(new Comparator<File>() {
public int compare(File o1, File o2) {
int answer;
if (o1.lastModified() == o2.lastModified()) {
answer = 0;
} else if (o1.lastModified() > o2.lastModified()) {
answer = 1;
} else {
answer = -1;
}
return -1 * answer;
}
})
.skip(numOfNewestToLeave)
.forEach(item -> item.delete());
#1 热门回答(150 赞)
你可以通过将其包装在lambda中来调整你在How to sort ArrayList<Long> in Java in decreasing order?中链接的解决方案:.sorted((f1, f2) -> Long.compare(f2.lastModified(), f1.lastModified())
请注意,f2是Long.compare
的第一个参数,而不是第二个参数,因此结果将被反转。
#2 热门回答(70 赞)
顺便说一句:如果你的流元素实现了887852407,那么它变得简单:
...stream()
.sorted(Comparator.reverseOrder())
#3 热门回答(39 赞)
使用
Comparator<File> comparator = Comparator.comparing(File::lastModified);
Collections.sort(list, comparator .reversed());
然后
.forEach(item -> item.delete());