首页 > 其他 > 详细

Future Clalback使用案例

时间:2018-06-28 22:26:40      阅读:214      评论:0      收藏:0      [点我收藏+]

目前知道可以实现线程按照顺序的java原生方法有 join(),CountDownLatch,Executors.newSingleThreadExecutor(),FutureTask..

Future Clalback配合使用

package com.juc.threadpool;

import java.util.concurrent.*;

/**
 * Created by Administrator on 2018/6/28.
 */
public class FutureCallBack {

    public static void main(String[] args) throws ExecutionException, InterruptedException {

        Callable<Integer> callable = () -> {
            TimeUnit.MILLISECONDS.sleep(3000);
            return 3;
        };

        FutureTask futureTask = new FutureTask(callable);
        FutureTask futureTask2 = new FutureTask(new MyTask());
        new Thread(futureTask).start();

        System.out.println(futureTask.get());//阻塞
        System.out.println("ssssssssssssssssssssss");
        new Thread(futureTask2).start();
        System.out.println(futureTask2.get());//阻塞
        System.out.println("ssssssssssssssssssssss");
        if(futureTask.isDone()){
            new Thread(futureTask2).start();
        }
        System.out.println(futureTask2.get());//阻塞


        //线程池使用
        ExecutorService executorService = Executors.newSingleThreadExecutor();
         executorService.submit(futureTask);
        System.out.println(futureTask.get());
        executorService.shutdown();
    }

    static class MyTask implements Callable<Integer> {

        @Override
        public Integer call() throws Exception {
            Thread.sleep(1000);
            return 1;
        }
    }

}

 

Future Clalback使用案例

原文:https://www.cnblogs.com/jinjian91/p/9241088.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!