集流的交集成新集

Gáb*_*ták 9 java-8 java-stream

对这个问题有更好,更简单的方法吗?

@Test
public void testReduce() {
    Set<Integer> foo = ImmutableSet.of(1,2,3,4,8,9);
    Set<Integer> bar = ImmutableSet.of(1,3,8,5,11);

    //DO think about solution for 1..n sets, and not only two.
    Set<Integer> intersection = ImmutableList.of(foo,bar)
            .stream()
            .reduce( null, (a, b) -> {
                if ( a == null ) {
                    a = new HashSet<Integer>(b);
                }
                else {
                    a.retainAll(b);
                }
                return a;
            });
    assertThat( intersection, is( ImmutableSet.of( 1,3,8) ) );
}
Run Code Online (Sandbox Code Playgroud)

Hol*_*ger 9

reduce这是错误的方法,因为你不允许以这种方式修改函数的参数.这是一种可变的减少,也称为collect:

List<Set<Integer>> listOfSets=…;
//check if at least one set is in the list
Set<Integer> intersection = listOfSets.stream().skip(1)
    .collect(()->new HashSet<>(listOfSets.get(0)), Set::retainAll, Set::retainAll);
Run Code Online (Sandbox Code Playgroud)

必须先查看第一个集合,这里是一个缺点,但使用null身份值也不干净(并且collect由于累加器无法返回新集合而无法使用).

  • 所以listOfSets.stream().skip(1)应该可以解决问题 (2认同)