Java异步编程之Callbacks与Futures模型怎么调用

寻技术 JAVA编程 2023年11月21日 83

本文小编为大家详细介绍“Java异步编程之Callbacks与Futures模型怎么调用”,内容详细,步骤清晰,细节处理妥当,希望这篇“Java异步编程之Callbacks与Futures模型怎么调用”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

    一、Callbacks模型

    该模型的异步方法,在异步任务完成之后调用,主线程没有异步线程的结果。经典模型如Swing’s EventListener模型

    1.1示例

    public class CallbackModel implements Callback, Runnable {
        @Override
        public void invoke() {
            System.out.println("这是异步回调的结果");
        }
        @Override
        public void run() {
            try {
                System.out.println(Thread.currentThread().getName() + "::异步线程任务开始");
                Thread.sleep(1000);
                System.out.println(Thread.currentThread().getName() + "::异步线程任务结束");
                invoke();
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
        public static void main(String[] args) {
            System.out.println(Thread.currentThread().getName() + "::主线程开始");
            new Thread(new CallbackModel(), "线程一").start();
            System.out.println(Thread.currentThread().getName() + "::主线程结束");
        }
    }
    interface Callback {
        void invoke();
    }

    1.2运行结果

    main::主线程开始
    main::主线程结束
    线程一::异步线程任务开始
    线程一::异步线程任务结束
    这是异步回调的结果

    二、Futures模型

    该模型的异步方法,立刻返回一个包装了结果的返回值Future,T即是包装的返回值,但返回值不可立即访问(异步方法为完成),Future对象包装了对它的访问。可以轮询对象,直到该值可用为止。

    2.1用例

    public class FutureModel {
    
        static class FutureTask implements Callable {
    
            @Override
            public Object call()  {
                try {
                    System.out.println(Thread.currentThread().getName() + "::异步线程任务开始");
                    Thread.sleep(4000);
                    System.out.println(Thread.currentThread().getName() + "::异步线程任务结束");
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
                return "1234";
            }
        }
    
    
        public static void main(String[] args) {
            ExecutorService pool = Executors.newSingleThreadExecutor();
            Future<String> submit = pool.submit(new FutureTask());
            try {
                System.out.println(Thread.currentThread().getName() + "返回的结果::" + submit.get());
            } catch (InterruptedException e) {
                e.printStackTrace();
            } catch (ExecutionException e) {
                e.printStackTrace();
            }finally {
                pool.shutdown();
            }
        }
    }

    2.1用例结果

    pool-1-thread-1::异步线程任务开始
    pool-1-thread-1::异步线程任务结束
    main返回的结果::1234

    三、Future接口

    /**
    *异步计算的结果
    */
    public interface Future<V> {
    
        /**
         * 尝试取消任务,有可能失败
         */
        boolean cancel(boolean mayInterruptIfRunning);
    
        /**
         * 判断是否取消
         *
         * @return {@code true} if this task was cancelled before it completed
         */
        boolean isCancelled();
    
        /**
         *  * 判断是否完成
         *
         * @return {@code true} if this task completed
         */
        boolean isDone();
    
        /**
         * 等待直至获取结果
         */
        V get() throws InterruptedException, ExecutionException;
    
        /**
         * 等待指定的时间获取结果,否则抛出异常
         */
        V get(long timeout, TimeUnit unit)
            throws InterruptedException, ExecutionException, TimeoutException;
    }
    关闭

    用微信“扫一扫”