如何使用Java8 Lambda反向排序流?

出售Benda2:

我正在使用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());
阿德里安·莱昂哈德(Adrian Leonhard):

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

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

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

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章