Java线程 CompletionService
来源:互联网 发布:黎活明 知乎 编辑:程序博客网 时间:2024/06/06 04:34
CompletionService的使用
当我们使用ExecutorService创建一个线程池时, 如果执行了多个Callable任务后, 每个Callable任务都会产生一个Future, 如果我们需要处理这些任务产生的结果, 那么就需要将这些Future放入一个线性表中, 用于之后的数据处理.
有了CompletionService, 我们就不用人为地去创建线性表来存这些Future了, CompleService是一个更高级的EexcutorService, 它自身自带一个线程安全的线性表, 无需用户额外创建. 它提供了两个方法从线性表中取出结果: poll()是非阻塞的, 若目前无结果, 则返回null, 当前线程继续运行不阻塞; take()是阻塞的, 若当前无结果, 则当前线程阻塞, 直到产生一个结果, 被取出返回, 当前线程继续运行.
代码如下:
import java.util.concurrent.*;public class CompletionServiceTest { public static void main(String[] args) throws ExecutionException, InterruptedException { ExecutorService executorService = Executors.newCachedThreadPool(); CompletionService<Integer> completionService = new ExecutorCompletionService<Integer>(executorService); for (int i=0; i<5; i++) { completionService.submit(new Task()); } executorService.shutdown(); int count=0, index=1; while (count < 5) { Future<Integer> result = completionService.poll(); if (result == null) { System.out.println(index + " 没有发现有完成的任务"); }else { System.out.println(index + " 产生了一个随机数 " + result.get() ); count++; } index++; TimeUnit.SECONDS.sleep(2); } }}
import java.util.Random;import java.util.concurrent.Callable;import java.util.concurrent.TimeUnit;public class Task implements Callable<Integer> { @Override public Integer call() throws Exception { Random random = new Random(); TimeUnit.SECONDS.sleep(1); return random.nextInt(); }}
运行结果如下:
1 没有发现有完成的任务2 产生了一个随机数 10687299463 产生了一个随机数 -7540724284 产生了一个随机数 -7111208095 产生了一个随机数 -16965230686 产生了一个随机数 1409817456
阅读全文
0 0
- Java线程之CompletionService
- Java线程之CompletionService
- Java线程 CompletionService
- Java线程池CompletionService的简单应用
- java-CompletionService
- Java线程(七):AbstractExecutorService、CompletionService、ExecutorCompletionService
- java concurrent之CompletionService
- Java之CompletionService
- JAVA CallableAndFuture CompletionService
- 浅析Java CompletionService
- java CompletionService和ExecutorCompletionService
- Java CompletionService 理解
- 理解java的CompletionService
- Java之CompletionService
- Java多线程-CompletionService
- 【Java】CompletionService 使用
- java多线程中的CompletionService
- Java并发编程:CompletionService
- linux 创建内核线程
- Rx系列学习笔记_Rxjava的基本了解
- 排序算法——选择排序
- Qt学习01——字符串类
- 如何学习新技术
- Java线程 CompletionService
- java求质数,例子1-100
- ORACLE 查询高水位表 脚本
- ADO.NET学习之SqlDataAdapter,DataSet
- 特殊字符,# + %在url中传递,encode方式加密处理
- Android App异常退出时重新启动
- Core ML 与 Vision:iOS 11 机器学习教程
- Jackson详解一
- ubuntu16.04备份以及恢复