CompletableFuture异步编排

一、线程&线程池回顾

import java.util.concurrent.*;

public class ThreadTest {
    // 当前系统中线程池只有1-2个,每个异步任务,提交给线程池去执行
    public static ExecutorService service = Executors.newFixedThreadPool(10);

    public static void main(String[] args) {

        /*
        * 1) 继承Thread
        *       Thread01 thread = new Thread01();
        *       thread.start();
        * 2) 实现Runnable接口
        *       Runnable01 runnable01 = new Runnable01();
        *       new Thread(runnable01).start();
        * 3) 实现Callable接口 + FutureTask (可以拿到返回结果,可以处理异常)
        *       FutureTask<Integer> futureTask = new FutureTask<>(new Callable01());
        *       new Thread(futureTask).start();
        *       // 不同点,线程执行完成可以拿到返回结果
        *       Integer integer = futureTask.get();
        *       System.out.println(integer);
        * 4) 线程池
        *       给线程池直接提交任务
        *       service.execute(new Runnable01());
        *       1、创建
        *           1) Executors
        *           2) new ThreadPoolExecutor
        *
        * 区别:
        *       Thread与Runnable不能得到返回值,Callable可以获取返回值。
        *       以上三种方式都不能控制资源。
        *       线程池可以控制资源,性能稳定。
        */

        /*
         * 七大参数:
         *      corePoolSize: 核心线程数(线程池创建完成后就准备就绪的线程数量,等待来接受异步任务去执行。)
         *      maximumPoolSize: 最大线程数量(控制资源)。
         *      keepAliveTime: 存活时间(当前线程数量大于核心数量,释放空闲的线程 [只要线程空闲大于指定的keepAliveTime])。
         *      unit: 时间单位
         *      BlockingQueue<Runnable> workQueue: 阻塞队列。如果任务有很多,就会将目前多的任务放在队列里面。
         *                                                 只要线程空闲,就会去队列里面取出新的任务继续执行。
         *      threadFactory: 线程的创建工厂。
         *      handler: 如果队列满了,按照我们指定的拒绝策略拒绝执行任务。
         * 工作顺序:
         *  1、线程池创建,准备好核心线程数,准备接受任务。
         *  2、新任务进来,用核心线程中的空闲线程执行。
         *      1)核心线程满,那么再新进来的任务放入阻塞队列中。空闲的核心线程就会自己去阻塞队列获取任务执行.
         *      2)阻塞队列满了,就直接开新线程执行,最大只能开到max指定的数量
         *      3)max执行好了。max-core数量的空闲线程会在keepAliveTime指定的时间后自动销毁。最终保持在核心线程数的大小。
         *      4)如果线程数开到了max的数量,还有新任务进来,就会使用reject指定的拒绝策略进行处理。
         *  3、所有的线程创建都是由指定的 factory 创建。
         */
        ThreadPoolExecutor executor = new ThreadPoolExecutor(5, 200, 10, TimeUnit.SECONDS,
                new LinkedBlockingDeque<>(), Executors.defaultThreadFactory(), new ThreadPoolExecutor.AbortPolicy());

        // 创建一个可缓存线程池,如果线程池长度超过处理需要,可灵活回收空闲线程,若无可回收,则新建线程。
        ExecutorService cachedService = Executors.newCachedThreadPool();

        // 固定大小
        ExecutorService newFixedService = Executors.newFixedThreadPool(10);

        // 定时任务的线程池
        Executors.newScheduledThreadPool(10);

        // 单线程的线程池
        Executors.newSingleThreadExecutor();

        System.out.println("Main方法结束");
    }

    static class Thread01 extends Thread{
        @Override
        public void run() {
            System.out.println("当前线程:" + Thread.currentThread().getId());
            int i = 1;
            System.out.println("运行结果:" + i);
        }
    }

    static class Runnable01 implements Runnable{
        @Override
        public void run() {
            System.out.println("当前线程:" + Thread.currentThread().getId());
            int i = 1;
            System.out.println("运行结果:" + i);
        }
    }

    static class Callable01 implements Callable<Integer>{
        @Override
        public Integer call() throws Exception {
            System.out.println("当前线程:" + Thread.currentThread().getId());
            int i = 1;
            System.out.println("运行结果:" + i);
            return i;
        }
    }
}

二、异步编排

import java.util.concurrent.*;

public class CompletableFutureTest {
    public static ExecutorService executor = Executors.newFixedThreadPool(10);

    public static void main(String[] args) throws ExecutionException, InterruptedException {
        System.out.println("Main方法开始");

//        CompletableFuture<Void> runAsync = CompletableFuture.runAsync(() -> {
//            System.out.println("当前线程:" + Thread.currentThread().getId());
//            int i = 1;
//            System.out.println("运行结果:" + i);
//        }, executor);

         /*
         * 方法完成后的感知
         */
//        CompletableFuture<Integer> supplyAsync = CompletableFuture.supplyAsync(() -> {
//            System.out.println("当前线程:" + Thread.currentThread().getId());
//            int i = 1;
//            System.out.println("运行结果:" + i);
//            return i;
//        }, executor).whenComplete((result, exception)->{
//            // 虽然能得到异常信息,但没发修改返回数据
//            System.out.println("异步任务成功完成,输出结果为:" + result + "; 异常为:" + exception);
//        }).exceptionally(throwable -> {
//            // 感知异常同时返回默认值
//            return 10;
//        });

        /*
        * 方法执行完成后的处理
        */
//        CompletableFuture<Integer> supplyAsync1 = CompletableFuture.supplyAsync(() -> {
//            System.out.println("当前线程:" + Thread.currentThread().getId());
//            int i = 1;
//            System.out.println("运行结果:" + i);
//            return i;
//        }, executor).handle((result, exception)->{
//            if(result!=null){
//                return result * 2;
//            }
//            if(exception!=null){
//                return 0;
//            }
//            return 0;
//        });
//        Integer integer = supplyAsync.get();
//
//        System.out.println("Main方法结束: " + integer);

        /*
           线程串行化
           1) thenRun: 不能获取到上一步的执行结果
                        .thenRunAsync(() -> {
                    System.out.println("任务2启动");
                }, executor);
           2) thenAcceptAsync: 能接收上一步结果,但是无返回值
                        .thenAcceptAsync((result) -> {
                    System.out.println("任务2启动:" + result);
                }, executor);
           3) thenApplyAsync: 能接收上一步的结果,有返回值
         */

        CompletableFuture<String> future1 = CompletableFuture.supplyAsync(() -> {
            System.out.println("当前线程:" + Thread.currentThread().getId());
            int i = 1;
            System.out.println("运行结果:" + i);
            return i;
        }, executor).thenApplyAsync((result) -> {
            return "Hello" + result;
        }, executor);
        System.out.println("Main方法结束: "+future1.get());
    }
}

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值