lambdaj和Java中的多重排序条件



我喜欢lambdaj并经常使用它,但我似乎不知道是否可以使用多个排序条件对列表进行排序。

下面是一个使用谷歌收藏的例子。同样的事情能在lambdaj做吗?

先按颜色排序,然后按名称排序:

Function<Fruit, Color> getColorFunction = new Function<Fruit, Color>() {
public Color apply(Fruit from) {
    return from.getColor();
}
};
Function<Fruit, String> getNameFunction = new Function<Fruit, String>() {
public String apply(Fruit from) {
    return from.getName();
}
};
Ordering<Fruit> colorOrdering = Ordering.natural().onResultOf(getColorFunction);
Ordering<Fruit> nameOrdering = Ordering.natural().onResultOf(getNameFunction);
Ordering<Fruit> colorAndNameOrdering = colorOrdering.compound(nameOrdering);
ImmutableSortedSet<Fruit> sortedFruits = ImmutableSortedSet.orderedBy(
    colorAndNameOrdering).addAll(fruits).build();

官方Lambdaj页面上没有提供这样做的示例,但每次调用sort Lambdaj时,都会为给定的参数创建比较器。下面是一个如何按多个属性排序的示例。

排序:

public static void main(String... args) {
    final Comparator byName = new ArgumentComparator(on(Fruit.class).getName());
    final Comparator byColor = new ArgumentComparator(on(Fruit.class).getColor());
    final Comparator orderBy = ComparatorUtils.chainedComparator(byName, byColor);
    final List<Fruit> unsorted = Arrays.asList(...);
    final List<Fruit> sorted = sort(unsorted, on(Fruit.class), orderBy);
    System.out.println(sorted);
}

不利因素:

有一个非lambdaj第三方方法用法。ComparatorUtils.chainedComparator——它来自apachecommons集合。如果你的项目中没有这个依赖项,你可以自己写。它只是遍历所有比较器,直到返回非零

相关内容

  • 没有找到相关文章

最新更新