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

2022-08-31 05:36:40

我正在使用java lambda对列表进行排序。

我怎样才能以相反的方式对它进行排序?

我看到了这篇文章,但我想使用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

您可以通过将ArrayList<Long>包装在lambda中来调整Java中如何排序中链接的解决方案:

.sorted((f1, f2) -> Long.compare(f2.lastModified(), f1.lastModified())

请注意,f2 是 的第一个参数,而不是第二个参数,因此结果将反转。Long.compare


答案 2

如果您的流元素实现,则解决方案将变得更简单:Comparable

 ...stream()
 .sorted(Comparator.reverseOrder())

推荐