当前位置: 首页 > news >正文

并行流parallelStream.map().collect()

一、使用场景

  1. 先贴代码
public static void main(String[] args) {List<String> stringList = new ArrayList<>();List<Integer> integerList = new ArrayList<>();int num = 10000;for (int i = 0;i<num;i++){stringList.add(String.valueOf(i));}stringList.parallelStream().forEach(str->{integerList.add(Integer.parseInt(str));});System.out.println(stringList.size());System.out.println(integerList.size());
}--- 下面是执行一次的结果 ---
10000
5769

可以看出来:parallelStream实际上是为每一个流创建了一个线程,去执行后面的任务。由于是多线程环境下,流后面的foreach、map里的逻辑如果有共享变量需要自行保证线程安全。这里就是因为ArrayList不是线程安全的,所以integerList与stringList的数据不一致。

  1. 结论:用于多线程执行任务

二、进阶使用

上面的代码线程不安全,如何修改?
方式一,将integerList的实现改为线程安全的List

public static void main(String[] args) {List<String> stringList = new ArrayList<>();List<Integer> integerList = Collections.synchronizedList(new ArrayList<>());int num = 10000;for (int i = 0;i<num;i++){stringList.add(String.valueOf(i));}stringList.parallelStream().forEach(str->{integerList.add(Integer.parseInt(str));});System.out.println(stringList.size());System.out.println(integerList.size());
}--- 下面是执行一次的结果 ---
10000
10000

方式二:使用collect
parallelStream的map,collect,flatMap,reduce等操作已经自行保证了线程安全

public static void main(String[] args) {List<String> stringList = new ArrayList<>();int num = 10000;for (int i = 0; i < num; i++) {stringList.add(String.valueOf(i));}List<Integer> integerList = stringList.parallelStream().map(Integer::parseInt).collect(Collectors.toList());System.out.println(stringList.size());System.out.println(integerList.size());
}

三、常用案例

有时候,我们会for循环调用service获取多个List<T>的,最后把所有获取到的List<T>汇总起来,添加到结果集里。

  1. 用List<callable<List<T>>> callableList将多个并发任务添加进去,然后使用List<Future> futures = threadPoolExecutor.invokeAll(callableList),最后将所有future的调用结果get出来,添加到result
  2. 用parallelStream().map.collect
List<User> resultList = paramList.parallelStream()// 执行业务逻辑,根据参数查询n次.map(param -> {//todo 构建参数return userService.query(param);}).collect(Collectors.toList());

相关文章:

  • RaabitMQ 快速入门
  • 本地生活服务平台搭建方案详解:同城跑腿外卖系统源码一体化开发
  • 数据结构-串
  • 手机上的PDF精简版:随时随地享受阅读
  • 机器学习常用算法总结
  • 【第三章】17-常用模块5-ngx_http_gzip_module
  • 抗量子算法验证工具
  • 2025企业增长新引擎:AI Agent驱动人效跃迁|白皮书2.0发布
  • 物联网智慧教室项目(完整版)
  • 人工智能中的卷积神经网络(CNN)综述
  • JavaScript 调试
  • 内网Windows挂载目录到公网服务器
  • 深度学习(第1章——神经网络原理和Pytorch入门)
  • 【经验分享】基于Calcite+MyBatis实现多数据库SQL自动适配:从原理到生产实践
  • JLINK安装以及使用教程
  • 【AI News | 20250415】每日AI进展
  • uniapp+vue3全选、全不选 模板
  • ArrayList的subList的数据仍是集合
  • 微电网与分布式能源:智能配电技术的场景化落地
  • 面试期间大频率出现的问题
  • 美的集团一季度净利增长38%,库卡中国机器人接单增超35%
  • 中行一季度净赚超543亿降2.9%,利息净收入降逾4%
  • 逛了6个小时的上海车展。有些不太成熟的感受。与你分享。
  • 电话费被私改成48元套餐长达数年,投诉后移动公司退补600元话费
  • 武汉一季度GDP为4759.41亿元,同比增长5.4%
  • 中介在网上非法贩婴“一个孩子8.5万元”?丹阳警方介入