【CompletableFuture实战】

打印 上一主题 下一主题

主题 1047|帖子 1047|积分 3141

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?立即注册

x
媒介

过去的一年,急忙忙忙,换了一次工作,写博客的习惯就落下了,总之,有点怠惰。希望今年能重拾信心,步入正规!
CompletableFuture的用法网上资料颇多,我这里就简单纪录下自己项目中的真实场景(代码模拟思绪),算是抛砖引玉~
  1.     public void handleUserList(List<Users> userList) {
  2.         // 增加自定义线程池
  3.         ExecutorService executorService = new ThreadPoolExecutor(2, 2, 0, TimeUnit.SECONDS, new LinkedBlockingDeque<>(12));
  4.         List<Users> itDeptList = userList.stream().filter(name -> name.getDeptName().equals("IT")).collect(Collectors.toList());
  5.         if (CollectionUtils.isEmpty(itDeptList)) {
  6.             return;
  7.         }
  8.         CompletableFuture<Void> createFuture = CompletableFuture.runAsync(() -> {
  9.             // 模拟某线程执行业务,比如创建用户
  10.             usersMapper.insert(itDeptList.get(0));
  11.         }, executorService);
  12.         CompletableFuture<Void> updateFuture = CompletableFuture.runAsync(() -> {
  13.             List<Integer> userIds = itDeptList.stream().map(Users::getUserId).collect(Collectors.toList());
  14.             // 模拟某线程执行业务,比如根据ID列表查询用户
  15.             usersMapper.selectBatchIds(userIds);
  16.         }, executorService);
  17.         // 等待两个线程执行完毕,最后执行主线程
  18.         CompletableFuture.allOf(createFuture, updateFuture).join();
  19.     }
复制代码
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

反转基因福娃

论坛元老
这个人很懒什么都没写!
快速回复 返回顶部 返回列表