java foreach并行_java – Stream.forEach()总是并行工作吗?

Aggregating with Streams中,Brian Goetz比较使用Stream.collect()填充集合并使用Stream.forEach()执行相同操作,使用以下两个片段:

Set uniqueStrings = strings.stream()

.collect(HashSet::new,

HashSet::add,

HashSet::addAll);

和,

Set set = new HashSet<>();

strings.stream().forEach(s -> set.add(s));

然后他解释说:

The key

difference is that, with the forEach() version, multiple threads are trying to access a single result

container simultaneously, whereas with parallel collect(), each thread has its own local result

container, the results of which are merged afterward.

据我所知,只有当流是并行的时,多个线程才会在forEach()情况下工作.但是,在给出的示例中,forEach()在顺序流上运行(不调用parallelStream()).

那么,forEach()总是并行工作,或者代码片段应该调用parallelStream()而不是stream(). (或者我错过了什么?)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值