Callable Future

package advancedJava;

import java.util.Random;
import java.util.concurrent.*;

/**
 * callable和future是试验类
 *
 * @author: cuiH
 * Date: 13-11-27
 * 执行一个线程,取得线程返回的结果
 * callable 返回一个结果,future取到返回的结果。
 */
public class CallableAndFuture {
    public static void main(String[] args) throws ExecutionException, InterruptedException, TimeoutException {
        ExecutorService threadPool = Executors.newSingleThreadExecutor();
        Future<String> future = threadPool.submit(new Callable<String>() {
            @Override
            public String call() throws Exception {
                Thread.sleep(200);
                return "Hello Honey";
            }
        });//提交返回的结果
        System.out.println("等待结果");
        System.out.println("拿到结果:" + future.get(1, TimeUnit.SECONDS));
        //future可以添加参数,此处超过一秒没有取到,我就不取了

        ExecutorService threadPool2 = Executors.newFixedThreadPool(10);


        //提交一批量的结果,然后,立刻获得先获得的结果,同时捕获。应用需要查找
        CompletionService<Integer> completionService = new ExecutorCompletionService<Integer>(threadPool2);
        for (int i = 0; i < 10; i++) {
            final int finalI = i;
            completionService.submit(new Callable<Integer>() {
                @Override
                public Integer call() throws Exception {
                    Thread.sleep(new Random().nextInt(5000));
                    return finalI;
                }
            });
        }
        for (int i = 0; i < 10; i++) {
            System.out.println(completionService.take().get());
        }
    }
}

猜你喜欢

转载自rzy.iteye.com/blog/1986923
今日推荐