Java 利用JUC CountDownLatch 线程池Executors 实现多线程操作

简介: Java 利用JUC CountDownLatch 线程池Executors 实现多线程操作业务场景:某个业务操作非常耗时,但又必须等这个操作结束后才能进行后续操作

Java 利用JUC CountDownLatch 线程池Executors 实现多线程操作

业务场景:某个业务操作非常耗时,但又必须等这个操作结束后才能进行后续操作

importorg.springframework.util.CollectionUtils;

importjava.util.List;

importjava.util.concurrent.CountDownLatch;

importjava.util.concurrent.ExecutorService;

importjava.util.concurrent.Executors;

importjava.util.concurrent.TimeUnit;

importjava.util.function.Consumer;

importjava.util.stream.Collectors;

importjava.util.stream.Stream;

/**

* 多线程任务处理工具类

* gzh-JavaNice

*/

publicclassTaskDisposeUtils {

   //并行线程数

   publicstaticfinalintPOOL_SIZE;

   static {

       //判断核心线程数 如果机器的核心线程数大于5则用机器核心线程数

       POOL_SIZE=Integer.max(Runtime.getRuntime().availableProcessors(), 5);

   }

   /**

    * 并行处理,并等待结束

    *

    * @param taskList 任务列表

    * @param consumer 消费者

    * @param <T>

    * @throws InterruptedException

    */

   publicstatic<T>voiddispose(List<T>taskList, Consumer<T>consumer) throwsInterruptedException {

       dispose(true, POOL_SIZE, taskList, consumer);

   }

   /**

    * 并行处理,并等待结束

    *

    * @param moreThread 是否多线程执行

    * @param poolSize   线程池大小

    * @param taskList   任务列表

    * @param consumer   消费者

    * @param <T>

    * @throws InterruptedException

    */

   publicstatic<T>voiddispose(booleanmoreThread, intpoolSize, List<T>taskList, Consumer<T>consumer) throwsInterruptedException {

       if (CollectionUtils.isEmpty(taskList)) {

           return;

       }

       //如果是多线程且核心线程数大于一则进入方法

       if (moreThread&&poolSize>1) {

           poolSize=Math.min(poolSize, taskList.size());

           ExecutorServiceexecutorService=null;

           try {

               //新建一个固定大小的线程池 核心线程数为poolSize

               executorService=Executors.newFixedThreadPool(poolSize);

               //juc工具类 用于让必须所有任务都处理完后才进行下一步

               CountDownLatchcountDownLatch=newCountDownLatch(taskList.size());

               for (Titem : taskList) {

                   executorService.execute(() -> {

                       try {

                           //消费任务

                           consumer.accept(item);

                       } finally {

                           //处理完后减一

                           countDownLatch.countDown();

                       }

                   });

               }

               //在此等待 当countDownLatch变成0后才继续进行下一步

               countDownLatch.await();

           } finally {

               if (executorService!=null) {

                   executorService.shutdown();

               }

           }

       } else {

           for (Titem : taskList) {

               consumer.accept(item);

           }

       }

   }

  publicstaticvoidmain(String[] args) throwsInterruptedException {

       //生成1-10的10个数字,放在list中,相当于10个任务

       List<Integer>list=Stream.iterate(1, a->a+1).limit(10).collect(Collectors.toList());

       JSONObjectobject=newJSONObject();

       object.put("name","sss");

       //启动多线程处理list中的数据,每个任务休眠时间为list中的数值

//        Consumer<Integer> c= item -> {

//            try {

//                long startTime = System.currentTimeMillis();

//                object.put("s",item);

//                TimeUnit.SECONDS.sleep(item);

//                long endTime = System.currentTimeMillis();

//                System.out.println(object.toJSONString());

//                System.out.println(System.currentTimeMillis() + ",任务" + item + "执行完毕,耗时:" + (endTime - startTime));

//            } catch (InterruptedException e) {

//                e.printStackTrace();

//            }

//        };

       TaskDisposeUtils.dispose(list, item-> {

           try {

               longstartTime=System.currentTimeMillis();

               object.put("s",item);

               TimeUnit.SECONDS.sleep(item);

               longendTime=System.currentTimeMillis();

               System.out.println(object.toJSONString());

               System.out.println(System.currentTimeMillis() +",任务"+item+"执行完毕,耗时:"+ (endTime-startTime));

           } catch (InterruptedExceptione) {

               e.printStackTrace();

           }

       });

       //上面所有任务处理完毕完毕之后,程序才能继续

       System.out.println(list+"中的任务都处理完毕!");

   }

}

执行结果

🖊️最后总结

🖲要熟练掌握技巧,一定多多坚持练习:骐骥一跃,不能十步;驽马十驾,功在不舍


目录
相关文章
|
9天前
|
安全 Java API
JAVA并发编程JUC包之CAS原理
在JDK 1.5之后,Java API引入了`java.util.concurrent`包(简称JUC包),提供了多种并发工具类,如原子类`AtomicXX`、线程池`Executors`、信号量`Semaphore`、阻塞队列等。这些工具类简化了并发编程的复杂度。原子类`Atomic`尤其重要,它提供了线程安全的变量更新方法,支持整型、长整型、布尔型、数组及对象属性的原子修改。结合`volatile`关键字,可以实现多线程环境下共享变量的安全修改。
|
13天前
|
存储 缓存 Java
什么是线程池?从底层源码入手,深度解析线程池的工作原理
本文从底层源码入手,深度解析ThreadPoolExecutor底层源码,包括其核心字段、内部类和重要方法,另外对Executors工具类下的四种自带线程池源码进行解释。 阅读本文后,可以对线程池的工作原理、七大参数、生命周期、拒绝策略等内容拥有更深入的认识。
什么是线程池?从底层源码入手,深度解析线程池的工作原理
|
6天前
|
Java Spring
spring多线程实现+合理设置最大线程数和核心线程数
本文介绍了手动设置线程池时的最大线程数和核心线程数配置方法,建议根据CPU核数及程序类型(CPU密集型或IO密集型)来合理设定。对于IO密集型,核心线程数设为CPU核数的两倍;CPU密集型则设为CPU核数加一。此外,还讨论了`maxPoolSize`、`keepAliveTime`、`allowCoreThreadTimeout`和`queueCapacity`等参数的设置策略,以确保线程池高效稳定运行。
51 10
spring多线程实现+合理设置最大线程数和核心线程数
|
13天前
|
存储 缓存 安全
【Java面试题汇总】多线程、JUC、锁篇(2023版)
线程和进程的区别、CAS的ABA问题、AQS、哪些地方使用了CAS、怎么保证线程安全、线程同步方式、synchronized的用法及原理、Lock、volatile、线程的六个状态、ThreadLocal、线程通信方式、创建方式、两种创建线程池的方法、线程池设置合适的线程数、线程安全的集合?ConcurrentHashMap、JUC
【Java面试题汇总】多线程、JUC、锁篇(2023版)
|
2天前
|
Java
直接拿来用:进程&进程池&线程&线程池
直接拿来用:进程&进程池&线程&线程池
|
4天前
|
Java 开发者
Java中的多线程基础与应用
【9月更文挑战第22天】在Java的世界中,多线程是一块基石,它支撑着现代并发编程的大厦。本文将深入浅出地介绍Java中多线程的基本概念、创建方法以及常见的应用场景,帮助读者理解并掌握这一核心技术。
|
6天前
|
Java
领略Lock接口的风采,通过实战演练,让你迅速掌握这门高深武艺,成为Java多线程领域的武林盟主
领略Lock接口的风采,通过实战演练,让你迅速掌握这门高深武艺,成为Java多线程领域的武林盟主
21 7
|
5天前
|
Java 程序员
Java中的多线程基础与实践
【9月更文挑战第21天】本文旨在引导读者深入理解Java多线程的核心概念,通过生动的比喻和实例,揭示线程创建、同步机制以及常见并发工具类的使用。文章将带领读者从理论到实践,逐步掌握如何在Java中高效地运用多线程技术。
|
3天前
|
Java 调度 开发者
Java中的多线程编程:从基础到实践
本文旨在深入探讨Java多线程编程的核心概念和实际应用,通过浅显易懂的语言解释多线程的基本原理,并结合实例展示如何在Java中创建、控制和管理线程。我们将从简单的线程创建开始,逐步深入到线程同步、通信以及死锁问题的解决方案,最终通过具体的代码示例来加深理解。无论您是Java初学者还是希望提升多线程编程技能的开发者,本文都将为您提供有价值的见解和实用的技巧。
13 2
|
5天前
|
Java 数据处理
Java中的多线程编程:从基础到实践
本文旨在深入探讨Java中的多线程编程,涵盖其基本概念、创建方法、同步机制及实际应用。通过对多线程基础知识的介绍和具体示例的演示,希望帮助读者更好地理解和应用Java多线程编程,提高程序的效率和性能。
17 1