一、声明
  public interface ExecutorService extends Executor 位于java.util.concurrent包下
  所有超级接口:Executor
  所有已知子接口:ScheduledExecutorService
  所有已知实现类:AbstractExecutorService, ScheduledThreadPoolExecutor, ThreadPoolExecutor
  二、概述
  Executor 提供了管理终止的方法,以及可为跟踪一个或多个异步任务执行状况而生成 Future 的方法。
  可以关闭 ExecutorService,这将导致其拒绝新任务。提供两个方法来关闭 ExecutorService.shutdown() 方法在终止前允许执行以前提交的任务,而shutdownNow() 方法阻止等待任务启动并试图停止当前正在执行的任务。在终止时,执行程序没有任务在执行,也没有任务在等待执行,并且无法提交新任务。应该关闭未使用的ExecutorService 以允许回收其资源。
  通过创建并返回一个可用于取消执行和/或等待完成的 Future,方法 submit 扩展了基本方法 Executor.execute(java.lang.Runnable)。方法 invokeAny 和 invokeAll 是批量执行的最常用形式,它们执行任务 collection,然后等待至少一个,或全部任务完成(可使用ExecutorCompletionService 类来编写这些方法的自定义变体)。
  Executors 类提供了用于此包中所提供的执行程序服务的工厂方法。
  下面给出了一个网络服务的简单结构,这里线程池中的线程作为传入的请求。它使用了预先配置的 Executors.newFixedThreadPool(int) 工厂方法:
  class NetworkService implements Runnable {
  private final ServerSocket serverSocket;
  private final ExecutorService pool;
  public NetworkService(int port, int poolSize)
  throws IOException {
  serverSocket = new ServerSocket(port);
  pool = Executors.newFixedThreadPool(poolSize);
  }
  public void run() { // run the service
  try {
  for (;;) {
  pool.execute(new Handler(serverSocket.accept()));
  }
  } catch (IOException ex) {
  pool.shutdown();
  }
  }
  }
  class Handler implements Runnable {
  private final Socket socket;
  Handler(Socket socket) { this.socket = socket; }
  public void run() {
  // read and service request on socket
  }
  }
  下列方法分两个阶段关闭 ExecutorService.第一阶段调用 shutdown 拒绝传入任务,然后调用 shutdownNow(如有必要)取消所有遗留的任务:
  void shutdownAndAwaitTermination(ExecutorService pool) {
  pool.shutdown(); // Disable new tasks from being submitted
  try {
  // Wait a while for existing tasks to terminate
  if (!pool.awaitTermination(60, TimeUnit.SECONDS)) {
  pool.shutdownNow(); // Cancel currently executing tasks
  // Wait a while for tasks to respond to being cancelled
  if (!pool.awaitTermination(60, TimeUnit.SECONDS))
  System.err.println("Pool did not terminate");
  }
  } catch (InterruptedException ie) {
  // (Re-)Cancel if current thread also interrupted
  pool.shutdownNow();
  // Preserve interrupt status
  Thread.currentThread()。interrupt();
  }
  }
  内存一致性效果:线程中向 ExecutorService 提交 Runnable 或 Callable 任务之前的操作happen-before 由该任务所提取的所有操作,后者依次 happen-before 通过 Future.get() 获取的结果。
  从以下版本开始:1.5
  三、方法详细
  1、void shutdown()
  启动一次顺序关闭,执行以前提交的任务,但不接受新任务。如果已经关闭,则调用没有其他作用。
  抛出: SecurityException - 如果安全管理器存在并且关闭,此 ExecutorService 可能操作某些不允许调用者修改的线程(因为它没有保持RuntimePermission("modifyThread")),或者安全管理器的 checkAccess 方法拒绝访问。
  2、List shutdownNow() 试图停止所有正在执行的活动任务,暂停处理正在等待的任务,并返回等待执行的任务列表。
  无法保证能够停止正在处理的活动执行任务,但是会尽力尝试。例如,通过 Thread.interrupt() 来取消典型的实现,所以任何任务无法响应中断都可能永远无法终止。
  返回: 从未开始执行的任务的列表
  抛出: SecurityException - 如果安全管理器存在并且关闭,此 ExecutorService 可能操作某些不允许调用者修改的线程(因为它没有保持RuntimePermission("modifyThread")),或者安全管理器的 checkAccess 方法拒绝访问。
  3、boolean isShutdown() 如果此执行程序已关闭,则返回 true.
  4、boolean isTerminated() 如果关闭后所有任务都已完成,则返回 true.注意,除非首先调用shutdown 或 shutdownNow,否则 isTerminated 永不为 true.
  5、boolean awaitTermination(long timeout, TimeUnit unit) throws InterruptedException www.yztrans.com
  请求关闭、发生超时或者当前线程中断,无论哪一个首先发生之后,都将导致阻塞,直到所有任务完成执行。
  参数:timeout - 最长等待时间
  unit - timeout 参数的时间单位
  返回:如果此执行程序终止,则返回 true;如果终止前超时期满,则返回 false
  抛出:InterruptedException - 如果等待时发生中断
  6、 Future submit(Callable task)
  提交一个返回值的任务用于执行,返回一个表示任务的未决结果的 Future.该 Future 的 get 方法在成功完成时将会返回该任务的结果。
  如果想立即阻塞任务的等待,则可以使用 result = exec.submit(aCallable)。get(); 形式的构造。
  注:Executors 类包括了一组方法,可以转换某些其他常见的类似于闭包的对象,例如,将 PrivilegedAction 转换为Callable 形式,这样就可以提交它们了。
  参数: task - 要提交的任务
  返回: 表示任务等待完成的 Future
  抛出: RejectedExecutionException - 如果任务无法安排执行
  NullPointerException - 如果该任务为 null
  7、 Future submit(Runnable task, T result)
  提交一个 Runnable 任务用于执行,并返回一个表示该任务的 Future.该 Future 的 get 方法在成功完成时将会返回给定的结果。
  参数: task - 要提交的任务 result - 返回的结果
  返回: 表示任务等待完成的 Future
  抛出: RejectedExecutionException - 如果任务无法安排执行
  NullPointerException - 如果该任务为 null
  8、Future submit(Runnable task)
  提交一个 Runnable 任务用于执行,并返回一个表示该任务的 Future.该 Future 的 get 方法在成功 完成时将会返回null.
  参数:task - 要提交的任务
  返回:表示任务等待完成的 Future
  抛出:RejectedExecutionException - 如果任务无法安排执行
  NullPointerException - 如果该任务为 null
  9、 List> invokeAll(Collection> tasks) throws InterruptedException
  执行给定的任务,当所有任务完成时,返回保持任务状态和结果的 Future 列表。返回列表的所有元素的 Future.isDone() 为true.注意,可以正常地或通过抛出异常来终止已完成 任务。如果正在进行此操作时修改了给定的 collection,则此方法的结果是不确定的。
  参数:tasks - 任务 collection
  返回:表示任务的 Future 列表,列表顺序与给定任务列表的迭代器所生成的顺序相同,每个任务都已完成。
  抛出:InterruptedException - 如果等待时发生中断,在这种情况下取消尚未完成的任务。
  NullPointerException - 如果任务或其任意元素为 null www.jamo123.com
  RejectedExecutionException - 如果所有任务都无法安排执行
  10、 List> invokeAll(Collection> tasks, long timeout, TimeUnit unit) throws InterruptedException
  执行给定的任务,当所有任务完成或超时期满时(无论哪个首先发生),返回保持任务状态和结果的 Future 列表。返回列表的所有元素的 Future.isDone() 为true.一旦返回后,即取消尚未完成的任务。注意,可以正常地或通过抛出异常来终止已完成 任务。如果此操作正在进行时修改了给定的 collection,则此方法的结果是不确定的。
  参数:tasks - 任务 collection timeout - 最长等待时间 unit - timeout 参数的时间单位 www.lefeng123.com
  返回:表示任务的 Future 列表,列表顺序与给定任务列表的迭代器所生成的顺序相同。如果操作未超时,则已完成所有任务。如果确实超时了,则某些任务尚未完成。
  抛出:InterruptedException - 如果等待时发生中断,在这种情况下取消尚未完成的任务
  NullPointerException - 如果任务或其任意元素或 unit 为 null
  RejectedExecutionException - 如果所有任务都无法安排执行
  11、 T invokeAny(Collection> tasks) throws InterruptedException, ExecutionException
  执行给定的任务,如果某个任务已成功完成(也就是未抛出异常),则返回其结果。一旦正常或异常返回后,则取消尚未完成的任务。如果此操作正在进行时修改了给定的 collection,则此方法的结果是不确定的。
  参数:tasks - 任务 collection
  返回:某个任务返回的结果
  抛出:InterruptedException - 如果等待时发生中断
  NullPointerException - 如果任务或其任意元素为 null
  IllegalArgumentException - 如果任务为空
  ExecutionException - 如果没有任务成功完成
  RejectedExecutionException - 如果任务无法安排执行
  12、 T invokeAny(Collection> tasks, long timeout, TimeUnit unit) throws InterruptedException, ExecutionException, TimeoutException
  执行给定的任务,如果在给定的超时期满前某个任务已成功完成(也就是未抛出异常),则返回其结果。一旦正常或异常返回后,则取消尚未完成的任务。如果此操作正在进行时修改了给定的 collection,则此方法的结果是不确定的。
  参数: tasks - 任务 collection timeout - 最长等待时间 unit - timeout 参数的时间单位
  返回: 某个任务返回的结果
  抛出: InterruptedException - 如果等待时发生中断
  NullPointerException - 如果任务或其任意元素或 unit 为 null
  TimeoutException - 如果在所有任务成功完成之前给定的超时期满
  ExecutionException - 如果没有任务成功完成
  RejectedExecutionException - 如果任务无法安排执行

转载于:https://www.cnblogs.com/tianchaoy/p/3642596.html

java中ExecutorService接口相关推荐

  1. Java中实现接口与继承的区别

    ** Java中实现接口与继承的区别 ** 首先,先来了解一下什么是接口和继承.接口一般是使用interface来定义的.接口定义同类的定义类似,分为接口的声明和接口体,其中接口体由常量定义和方法定义 ...

  2. Objective-C 入门(七)协议 protocol(JAVA中的接口)

    Objective-C 入门(七)协议 protocol(JAVA中的接口) 接口的作用想必大家都比较了解 OV中的 protocol 相比接口作用相似 语法稍有不同 1.先来看声明一个协议 在创建文 ...

  3. Java中的接口命名[关闭]

    本文翻译自:Interface naming in Java [closed] Most OO languages prefix their interface names with a capita ...

  4. java中接口什么时候用_我什么时候应该在java中使用接口?

    在Java中精确使用接口的一个很好的例子将是理想的,适用于任何特定的规则. 看看丹以前所有的问题,他似乎只是逐字逐句地张贴家庭作业/考试问题. 令人惊讶的是,这些不是考试题或其他-今天才找到这个网站, ...

  5. Java 中 Comparable 接口的意义和用法.

    在之前的博文中已经介绍了Java中Collection 接口和 Collections类. http://blog.csdn.net/nvd11/article/details/21516075 一, ...

  6. java中的接口的定义以及实现关系

    一.什么是接口? - 硬件接口:设备之间的连接方式 - 软件接口:程序代码,特殊的类,表示一种规范,是具有N个方法的特征集合. java中的接口: 专家说的多个抽象类的抽象就是接口. interfac ...

  7. java中get接口示例_Java即时类| 带示例的get()方法

    java中get接口示例 即时类的get()方法 (Instant Class get() method) get() method is available in java.time package ...

  8. java中get接口示例_Java LocalDateTime类| 带示例的get()方法

    java中get接口示例 LocalDateTime类的get()方法 (LocalDateTime Class get() method) get() method is available in ...

  9. JAVA中常用接口的介绍及使用示例 java lang Comparable

    分享一下我老师大神的人工智能教程!零基础,通俗易懂!http://blog.csdn.net/jiangjunshow 也欢迎大家转载本篇文章.分享知识,造福人民,实现我们中华民族伟大复兴! JAVA ...

最新文章

  1. DropDownList--下拉菜单
  2. PLSQL Developer概念学习系列之如何正确登录连接上Oracle(图文详解)
  3. php数字转英文,PHP金额数字转换成英文
  4. FZU1969(最大公约数之和)
  5. adb指令禁用软件_三星等安卓手机续航差?禁用部分系统组件后提升明显
  6. 迷你世界无人驾驶地铁火车_出口伊斯坦布尔地铁列车“云下线”
  7. 从outside对ASA防火墙身后ACS4.x进行管理测试
  8. 循环依赖 三级缓存解决
  9. Future和FutureTask实现异步计算
  10. nutch2.1抓取中文网站
  11. Windows 技术篇-通过注册表查找vc运行库所在位置实战演示,通过ProductCode查看vc++运行库安装位置
  12. 【TSP】基于matlab GUI免疫算法结合蚁群算法求解旅行商问题【含Matlab源码 1910期】
  13. 计算机网络地址怎么办,电脑ip地址错误怎么办 电脑ip地地址错误解决方法
  14. 【前端知识之Vue】Vue常用的修饰符
  15. Linux学习(一)初识Linux(适合萌懂阶段)
  16. 台式机外接显示器后没有声音
  17. csp-j2第四题解
  18. 分布式锁的实现【转载】
  19. python怎么处理通达信ctp接口数据?
  20. scratch做出按键控制屏幕滚动效果

热门文章

  1. 骁龙870和麒麟970哪个好 骁龙870和麒麟970对比哪个性能强
  2. tsMuxeR使用方法
  3. 树莓派4B安装联想LJ2605D打印机驱动
  4. XMOS软件开发入门(1) - 开发板硬件资源介绍
  5. html中表格布局还是div布局,表格布局和css div布局
  6. 如何更改域计算机用户名和密码错误,当域用户尝试更改其密码在另一个域中的 UPN 格式中的所指定的帐户不存在错误信息...
  7. Win10 64位系统8G内存升级到10G后,显示3.92G可用解决办法
  8. Xilinx MIG 控制器使用详解(一)
  9. STM32-外部中断
  10. xctf攻防世界 MISC高手进阶区 Reverse-it