2021-06-03

ThreadPoolExecutor多线程执行callable,FutureTask获取返回值

定义callable类

public class MyThread implements Callable<Integer> {
    @Override
    public Integer call() throws Exception {
        int i = new Random().nextInt(100);
        Thread.sleep(1000);
        System.out.println(Thread.currentThread().getName()+"任务执行结果"+i);
        return i;
    }
}

测试代码

public class ThreadTest {
    public static void main(String[] args) throws ExecutionException, InterruptedException {
        // 任务集合
        List<FutureTask<Integer>> futureTasks = new ArrayList<FutureTask<Integer>>();
        // 线程池
        ThreadPoolExecutor pool = new ThreadPoolExecutor(4, 8, 4L, TimeUnit.SECONDS, new ArrayBlockingQueue<Runnable>(5 ), Executors.defaultThreadFactory(), new ThreadPoolExecutor.AbortPolicy());
        long start = System.currentTimeMillis();
        for (int i = 0; i < 10; i++) {
            FutureTask<Integer> task = new FutureTask<>(new MyThread());
            futureTasks.add(task);
            pool.submit(task);
        }

        Integer count = 0;
        for (FutureTask<Integer> futureTask : futureTasks) {
            count += futureTask.get();
        }
        long end = System.currentTimeMillis();
        System.out.println("线程池计算完成,结果为"+count+"耗时"+(end-start)+"ms");
        pool.shutdown();

//        Runnable runnable = ()->{
//           for (int i = 0; i < 10; i++) {
//                try {
//                    Thread.sleep(1000);
//                } catch (InterruptedException e) {
//                    e.printStackTrace();
//                }
//                System.out.println("线程"+i);
//            }
//        };
//        new Thread(runnable).start();
        // 重试工具
//        Retryer<Boolean> retryer = RetryerBuilder.<Boolean>newBuilder()
//                .retryIfException()
//                .retryIfResult(Predicates.equalTo(Boolean.FALSE))
//                .withWaitStrategy(WaitStrategies.fixedWait(10,  TimeUnit.SECONDS))
//                .withStopStrategy(StopStrategies.stopAfterAttempt(3))
//                .build();
//        try {
//            retryer.call(new MyThread01());
//        } catch (Exception e) {
//            e.printStackTrace();
//        }

    }

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值