java parrallel for_Java并行流_parallelStream的使用方式

最近在同事的代码里,发现了->的代码,觉得有点惊讶和疑惑,虽然知道->{}是匿名函数的表达式,但却被parallelStream所吸引。

就像这样的代码:

List specialModelNeedToBeSaved =bom.parallelStream()

.filter(a->CodeStartWithList.getStartWithListOfModel().contains(a.getScpe().substring(0,2)))

.filter(b->"(".equals(b.getScpe().substring(3,4))||"(".equals(b.getScpe().substring(3,4)))

.collect(Collectors.toList());

看着挺长挺nb的,百度了才知道parallelStream是一个叫并行流的东西,Java1.8才加入的。它通过默认的ForkJoinPool,提高多线程任务的速度,默认线程数量等于运行计算机上的处理器数量。Java8为ForkJoinPool添加了一个通用线程池,这个线程池用来处理那些没有被显式提交到任何线程池的任务。当调用Arrays类上添加的新方法时,自动并行化就会发生。

注意哦,这里是并行,不是并发。因为是多个处理器同时处理,和并发还是有区别的。

我们可以用parallelStream来处理list里的元素,比如输出:

TestTwo testTwo = newTestTwo();

List list = new ArrayList<>();for(int i=1;i<100;i++)

list.add(i);

list.parallelStream().forEach(a->{

out.println(a);

});

这样输出是无序,当然我们也可以让它有序的!forEachOrdered就是按照list的顺序依次执行。

list.parallelStream().forEachOrdered(a->{

out.println(a);

});

我们也可以通过fiter来过滤list里的值,需要注意的是后面的匿名函数需要有true,false返回值,以此才能知道,哪些元素是需要被过滤的。

List p2 = list.parallelStream().filter(a->{if(a>95){return true;

}else{return false;

}

}).collect(Collectors.toList());

p2.parallelStream().forEachOrdered(a->{

out.println(a);

});

输出:96

97

98

99

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值