CompletableFuture多线程执行并发任务工具封装

  1. 工具类封装

public class ParallelTaskFactory {

    /**
     * 存储消费型任务
     */
    private final   List<CompletableFuture<Void>>    consumerTaskList = new CopyOnWriteArrayList<>();

    /**
     * 存储供给型任务
     */
    private final  List<CompletableFuture<Object>>  supplyTaskList = new CopyOnWriteArrayList<>();


    /**
     * 添加消费型任务
     * @param task
     */
    public  void  addVoidTask(IExecutorVoidTask  task){
        consumerTaskList.add(CompletableFuture.runAsync(task::doRun));
    }

    /**
     * 执行消费型任务
     */
    @SuppressWarnings("unchecked")
    public  void   doVoidTasks(){
        if(!consumerTaskList.isEmpty()){
            CompletableFuture<Void>[] completableFutures = consumerTaskList.toArray(new CompletableFuture[0]);
            /// 全部并行执行结束时结束任务
            CompletableFuture.allOf(completableFutures).join();
        }
    }

    /**
     * 添加供给型任务
     * @param task
     */
    public   void  addSupplyTask(IExecutorSupplyTask task){
        supplyTaskList.add( CompletableFuture.supplyAsync(task::doRun));
    }


    /**
     * 执行供给型任务
     */
    @SuppressWarnings("unchecked")
    public List<Object>  doSupplyTasks(){
        List<Object>  list = new ArrayList<>();
        if(!supplyTaskList.isEmpty()) {
            CompletableFuture<Object>[] completableFutures = supplyTaskList.toArray(new CompletableFuture[0]);
            /// 全部并行执行结束时结束任务
            CompletableFuture.allOf(completableFutures).join();

            Arrays.stream(completableFutures).forEach(c->{
                try {
                    Object o = c.get();
                    list.add(o);
                } catch (Exception e) {
                    e.printStackTrace();
                }
            });
        }
        return list;
    }

    @FunctionalInterface
    public  interface IExecutorVoidTask {
        /**
         * 执行消费任务
         */
        void  doRun();
    }

    @FunctionalInterface
    public  interface IExecutorSupplyTask {
        /**  执行供给任务
         * @return
         */
        Object  doRun();
    }
}
  1. 调用测试

多线程调用远程接口

    public  String   testThread(Integer num){
        if(ObjectUtils.isEmpty(num)){
            num = 1;
        }
        long s = System.currentTimeMillis();
        ParallelTaskFactory parallelTaskFactory  = new ParallelTaskFactory();
        for (int i = 0; i < num; i++) {
            parallelTaskFactory.addSupplyTask(() -> {
                ResponseEntity<String> sout = restTemplate.getForEntity("http://127.0.0.1:8888/thread/msg?name="+Thread.currentThread().getName(), String.class);
                return sout.getBody();
            });
        }
        List<Object> list = parallelTaskFactory.doSupplyTasks();
        for (Object o : list) {
            LOGGER.info("多线程请求接口响应  {}:",o);
        }
        long e = System.currentTimeMillis();
        return  SDF.format(new Date())+"--线程执行完毕testThread,共耗时:"+(e-s)+"毫秒";
    }
  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java是一种面向对象的编程语言,它提供了强大的多线程支持。多线程允许程序同时执行多个任务,从而提高程序的并发性和响应速度。 在Java中实现多线程主要有以下几种方式: 1. **继承Thread类**:这是最简单的方式,创建一个类继承Thread类,并重写run()方法。当启动这个线程时,会调用这个run()方法。 ```java class MyThread extends Thread { public void run() { // 线程执行的代码 } } // 在其他地方使用这个线程 MyThread thread = new MyThread(); thread.start(); ``` 2. **实现Runnable接口**:这种方式比继承Thread类更灵活,因为Runnable是一个接口,它可以用来封装需要被多个线程调用的对象。创建Runnable对象并实现一个构造函数来接受Thread对象,然后通过该Thread对象启动新线程。 ```java class MyRunnable implements Runnable { public void run() { // 线程执行的代码 } } // 在其他地方使用这个Runnable对象创建新线程 Thread thread = new Thread(new MyRunnable()); thread.start(); ``` 3. **使用CallableFuture**:Callable是一个比Runnable更高级的接口,它允许你指定任务是否成功完成。你可以使用ExecutorService来执行Callable任务,并获取Future对象来查询任务是否完成以及结果。这种方式适合于需要返回结果的任务。 4. **使用线程池**:使用线程池可以更有效地利用系统资源,避免频繁创建和销毁线程带来的开销。Java提供了一个Executor框架,你可以使用它来创建和管理线程池。 5. **并发集合**:Java的并发包(java.util.concurrent)提供了许多并发集合类,如ConcurrentHashMap、CopyOnWriteArrayList等,这些类可以在多线程环境下安全地使用。 6. **Java NIO(New IO)包**:Java NIO包提供了一种更高效的IO模型,通过非阻塞和并行的IO操作,可以实现更高效的并发处理。 7. **CompletableFuture类**:这是Java 8引入的一个新的工具类,用于异步编程和协程。CompletableFuture允许你在多个线程之间安全地传递结果和异常。 以上就是在Java中实现多线程的一些主要方式。选择哪种方式取决于你的具体需求和场景。一般来说,如果你的任务是简单的IO操作或者不需要返回结果,使用继承Thread或者实现Runnable接口就足够了。如果你的任务更复杂,可能需要使用CallableFuture、线程池、并发集合等更高级的工具
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值