如何使用Java8 lambda以相反的顺序对流进行排序?

问题

我正在使用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());