处理完流之后,如果想查看结果,可以调用toArray方法获得含有流中所有元素的一个数组。
由于无法再运行时创建一个泛型数组,所以表达式stream.toArray()会返回一个Objec[]数组。如果希望得到一个正确类型的数组,可以将类型传递给数组的构造函数:
String[] result = words.toArray(String[] :: new);
如果希望收集到一个HashSet中,如果这个过程是并行的,那么不能将所有元素放到一个单独的HashSet中,因为HashSet对象不是线程安全的,因此提供了一个collect方法,他接受三个参数:
- 一个能创建目标类型实例的方法,例如HashSet的构造函数
- 一个将元素添加到目标中的方法,例如一个add方法
- 一个将两个对象整合到一起的方法,例如addAll方法。
注:目标对象不一定是集合,他可以是一个StringBuilder对象或是一个可以记录个数和总和的对象
HashSet<String> result = stream.collect(HashSet::new, HashSet::add, HashSet::addAll);
在实际中不需要这么做,Collector接口已经提供了这三个方法,并且Collectors类还为常用的收集类型提供了各个工厂方法。
-
要将流收集到一个list或set中
List<String> result = stream.collect(Collectors.toList()); Set<

Java流处理完成后,可以使用toArray方法获取元素数组。为了确保类型正确,需传入构造函数。若要收集到HashSet,由于其非线程安全,可使用collect方法结合Collector接口。Collectors提供了多种收集到list、set、StringBuilder等的工厂方法。此外,可用 summaring 方法计算总和、平均值等统计信息。对于Map,toMap方法用于生成Map,处理重复键需提供重写策略。并行处理时,可使用toConcurrentMap创建并发Map。
最低0.47元/天 解锁文章

被折叠的 条评论
为什么被折叠?



