**1. 控制任务组**
即将多个任务通通放到一个集合中,然后调用执行器依次执行每个任务。
<br/>
**2. 实现控制任务组代码块**
* 写法一:缺点是如果第一个任务花费了太多的时间,,则必须等待该线程。
```
// 将所有的任务存储到集合中
List<Callable<T>> tasks = ...;
// 将所有的任务提交到执行器中,并返回每个任务的处理结果
// executor为Executor类对象
List<Future<T>> results = executor.invokeAll(tasks);
// 依次处理每个任务的结果
for (Future<T> result : results) {
// 通过service.take().get()获取处理结果,然后对结果自行处理
// processFurther是自定义的处理方法
processFurther(service.take().get())
}
```
* 写法二:建议使用该写法。
```
// 将所有的任务存储到集合中
List<Callable<T>> tasks = ...;
// 将执行器提交到ExecutorCompletionService对象中
// executor为Executor类对象
ExecutorCompletionService<T> service = new ExecutorCompletionService<>(executor);
// 依次将任务提交到ExecutorCompletionService对象中
for (Callable<T> task : tasks {
service.submit(task);
}
// 依次处理每个任务的结果
for (int i = 0; i < tasks.size(); i++) {
// 通过service.take().get()获取处理结果,然后对结果自行处理
// processFurther是自定义的处理方法
processFurther(service.take().get());
}
```
* java.util.concurrent.ExecutorService 5.0
* `T invokeAny(Collection<Callable<T>> tasks)`
* `T invokeAny(Collection<Callable<T>> tasks, long timeout, TimeUnit unit)`
执行给定的任务,返回其中一个任务的结果。第二个方法发生超时,则抛出TimeoutException异常。
* `List<Future<T>> invokeAll(Collection<callable<T>> tasks)`
* `List<Future<T>> invokeAll(Collection<Callable<T>> tasks, long timeout, TimeUnit unit)`
执行给定的任务,返回所有任务的结果。第二个方法发生超时,则抛出TimeoutException异常。
* java.util.concurrent.ExecutorCompletionService< V> 5.0
* `ExecutorCompletionService(Executor e)`
构建一个执行器来完成服务,并收集给定执行器执行的结果。
* `Future<V> submit(Callable<V> task)`
* `Future<V> submit(Runnable task, V result)`
提交一个任务给底层的执行器。
* `Future<V> take()`
移除下一个已完成的结果,如果没有任何已完成结果,则阻塞。
* `Future<V> poll()`
* `Future<V> poll(long time, TimeUnit unit)`
移除下一个已完成的结果,
- 网络通信
- 网络协议
- 端口和套接字
- TCP网络程序
- UDP网络程序
- 多线程聊天室
- 多线程
- 线程相关概念
- 线程实现方式
- 中断线程
- 线程生命周期
- 线程优先级
- 优先级规则
- 案例演示
- 线程同步机制
- 线程同步机制
- synchronized关键字
- ReentrantLock类
- Condition类
- 监视器概念
- volatile关键字
- final变量
- 死锁
- 线程局部变量
- 读/写锁
- 原子类
- 阻塞队列
- 工作规则
- 案例演示
- 常用阻塞队列
- 线程安全集合
- 高效的映射/集/队列
- 并发集视图
- 写数组的拷贝
- Arrays类的并行数组算法
- 同步包装器
- Callable与Future
- 执行器
- 线程池
- 预定执行
- 控制任务组
- Fork-Join框架
- 同步器
- 同步器
- 信号量
- CountDownLatch类
- CyclicBarrier类
- Exchanger类
- SynchronousQueue类
- 线程与Swing
- Swing与线程问题
- 两个原则
- Swing工作线程
- 单一线程规则
- 文件IO
- File类
- 文件输入输出
- ZIP压缩文件
- 集合
- 集合框架
- 集合接口
- 集合实现类
- 线程安全集合
- 集合算法
- 迭代器
- 集合排序
- JDBC
- JDBC是什么
- JDBC-ODBC桥
- JDBC驱动程序类型
- JDBC常用类与接口
- 数据库操作
- 连接数据库
- 增/删/改/查/预处理
- 事务
- 批处理
- commons-dbutils工具
- 安全问题
- Jedis
- 使用Jedis操作Redis数据库
- JSON转换
- 使用连接池
- 案例
- 单例破坏
- 单例定义
- 单例实现方式
- 懒汉式实现单例
- 饿汉式实现单例
- 单例破坏
- 类的单例破坏
- 枚举的单例破坏
- 克隆
- 克隆是什么
- 浅克隆
- 深克隆
- 注解
- 注解是什么
- 三大注解
- 内置注解
- 元注解
- 自定义注解
- NIO
- 相关概念
- BIO/NIO/AIO
- 多线程编程
- 线程同步
- 线程通信
- NIO
- NIO三大核心组件
- NIO网络编程
- NIO文件读写
- AIO
- Java8新特性
- Lambda表达式
- 方法引用
- 函数式接口
- 默认方法
- 什么是默认方法
- 默认方法语法格式
- 多个同名的默认方法问题
- 静态默认方法
- 默认方法实例
- Stream
- Stream是什么
- Stream示例
- Optional容器
- 新的日期时间API
- Base64
- SPI
- SPI是什么
- SPI与API的区别
- 常见场景
- 使用SPI需遵循的约定
- SPI使用步骤