如何使用java8通过谓词对列表进行分区?

我有一个列表,我想分成几个小清单。

说出包含“aaa”的所有项目,包含“bbb”和更多谓词的所有内容。

我怎么能用java8这样做?

我看到这篇文章,但它只分成两个列表。

 public void partition_list_java8() { Predicate startWithS = p -> p.toLowerCase().startsWith("s"); Map<Boolean, List> decisionsByS = playerDecisions.stream() .collect(Collectors.partitioningBy(startWithS)); logger.info(decisionsByS); assertTrue(decisionsByS.get(Boolean.TRUE).size() == 3); } 

我看过这篇文章 ,但它在Java 8之前很老了。

就像它在@RealSkeptic 评论中所解释的那样, Predicate只能返回两个结果:true和false。 这意味着您只能将数据拆分为两组。
您需要的是某种Function ,它允许您确定应该组合在一起的元素的一些常见结果。 在你的情况下,这样的结果可能是小写的第一个字符(假设所有字符串都不是空的 – 至少有一个字符)。

现在使用Collectors.groupingBy(function)您可以将所有元素分组到单独的列表中,并将它们存储在Map中,其中key将是用于分组的常用结果(如第一个字符)。

所以你的代码看起来像

 Function firstChar = s -> Character.toLowerCase(s.charAt(0)); List a = Arrays.asList("foo", "Abc", "bar", "baz", "aBc"); Map> collect = a.stream() .collect(Collectors.groupingBy(firstChar)); System.out.println(collect); 

输出:

 {a=[Abc, aBc], b=[bar, baz], f=[foo]} 

您可以使用Collectors.groupingBy来转换(分组) – >(该分组中的事物列表)的流。 如果您不关心分组本身,则调用该映射上的values()以获取分区的Collection>