JUC学习之FutureTask

package future;

import java.util.ArrayList;
import java.util.List;
import java.util.Random;
import java.util.concurrent.Callable;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.FutureTask;
import java.util.concurrent.TimeUnit;

/**
 * 配合线程池使用FutureTask
 * */
public class FutureTask2 {
    
    /**
     * @param args
     */
    public static void main(String[] args) throws Exception{
        // TODO Auto-generated method stub
        List<FutureTask<Integer>> list = new ArrayList<FutureTask<Integer>>();
        ExecutorService es = Executors.newFixedThreadPool(10);
        for(int i=0;i<50;i++){
            FutureTask<Integer> ft = new FutureTask<Integer>(new SubTask1(i));
            //不可在次计算获取结果,会让异步变同步
            es.submit(ft);
            list.add(ft);
        }
        //循环统计结果
        Integer total = 0;
        for(FutureTask<Integer> f:list){
            try {
                total+=f.get();
            } catch (InterruptedException e) {
                // TODO Auto-generated catch block
            } catch (ExecutionException e) {
                e.printStackTrace();
            }
        }
        // 处理完毕,一定要记住关闭线程池,这个不能在统计之前关闭,因为如果线程多的话,执行中的可能被打断
        es.shutdown();
        es.awaitTermination(10, TimeUnit.MINUTES);
        System.out.println("统计结果:"+total);
    }

}
class SubTask1 implements Callable<Integer>{
    private Integer total;
    private Integer sum = 0;
    public SubTask1(Integer total){
        this.total = total;
    }
    @Override
    public Integer call() throws Exception {
        for(int i=0;i<total;i++){
            sum+=i;
        }
        System.out.println(Thread.currentThread().getName() + " sum:" + sum);
        return sum;
    }
}


转载于:https://my.oschina.net/sharkbobo/blog/267414

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值