并发执行任务

此博客展示了一段Java代码,利用ThreadPoolExecutor线程池和CountDownLatch处理好友列表过滤任务。代码中定义了7个Callable任务,分别用于去掉不同类型的好友,最后通过线程池执行这些任务,并对结果进行处理。

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

@Test
public void lastestFeeds() {
    ThreadPoolExecutor executor = new ThreadPoolExecutor(10, 20,
            1000L, TimeUnit.MILLISECONDS,
            new LinkedBlockingQueue<Runnable>(1000));
    CountDownLatch latch = new CountDownLatch(7);
    List<Callable<String>> tasks = new ArrayList<>(7);
    tasks.add(new Callable<String>() {
        @Override
        public String call() throws Exception {
            //1. 获取你得好友列表
            return "a";
        }
    });
    tasks.add(new Callable<String>() {
        @Override
        public String call() throws Exception {
            //2. 去掉把你删除的好友
            return "b";
        }
    });
    tasks.add(new Callable<String>() {
        @Override
        public String call() throws Exception {
            //3. 去掉被你删除的好友
            return "c";
        }
    });
    tasks.add(new Callable<String>() {
        @Override
        public String call() throws Exception {
            //4. 去掉被你设置过"不看他(她)的朋友圈"的好友
            return "d";
        }
    });
    tasks.add(new Callable<String>() {
        @Override
        public String call() throws Exception {
            //5. 去掉对你设置过"不让他(她)看我的朋友圈"的好友
            return "e";
        }
    });
    tasks.add(new Callable<String>() {
        @Override
        public String call() throws Exception {
            //6. 去掉被你拉黑和把你拉黑的好友
            return "f";
        }
    });
    tasks.add(new Callable<String>() {
        @Override
        public String call() throws Exception {
            //7. 去掉被微信系统标记为作弊的好友
            return "g";
        }
    });
    List<String> list=new LinkedList<>();
    try {
        //List<Future<String>> futureList = executor.invokeAll(tasks);
        List<Future<String>> futureList = executor.invokeAll(tasks, 500, TimeUnit.MILLISECONDS);
        for(Future<String> future : futureList) {
            if(future.isCancelled()) {
                //处理
            }
            try {
                future.get();
                list.add(future.get());
            } catch (ExecutionException e) {
                e.printStackTrace();
            }
        }
    } catch (InterruptedException e) {
        e.printStackTrace();
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值