java多线程编程获取线程返回值:ExecutorCompletionService

本文介绍了一个使用Java实现的简单并发下载任务管理系统。该系统通过固定大小的线程池执行多个下载任务,并利用CompletionService来管理这些异步任务的完成状态。每个下载任务作为一个独立的Callable对象被执行,完成后会返回一个整数标识文件编号。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

package com.shop;

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

/**
 * @author liuyong 2012-3-22
 */
public class App {

    private static final ExecutorService   NEW_FIXED_THREAD_POOL = Executors.newFixedThreadPool(10);
        private static CompletionService<Integer> completionService     = new ExecutorCompletionService<Integer>(
                                                                         NEW_FIXED_THREAD_POOL);


	public static void main(String[] args) {
        for (int i = 0; i < 10; i++) {
            DownLoader<Integer> downLoader = new DownLoader<Integer>();
            downLoader.setIndex(i);
            completionService.submit(downLoader);
        }
        for (int i = 0; i < 10; i++) {
            try {
                Future<Integer> future = completionService.take();
                Integer str = future.get();
                System.out.println("take file [" + str + "];" + "time ["
                                   + new Date() + "];");
            } catch (InterruptedException e) {
                break;
            } catch (ExecutionException e) {
                break;
            }
        }
        NEW_FIXED_THREAD_POOL.shutdown();
        System.out.println("ok");
	}

    private static class DownLoader<Integer> implements Callable<Integer> {

        private Integer index;

        public void setIndex(Integer index) {
            this.index = index;
        }

        public Integer call() throws Exception {
            try {
                Random random = new Random();
                Thread.sleep(random.nextInt(20) * 1000);
            } catch (InterruptedException e) {
                System.out.println(e);
            }
            return index;
        }
    }
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值