JDK文档说明:

  1. 创建一个可重用固定线程数的线程池,以共享的无界队列方式来运行这些线程。在任意点,在大多数 nThreads 线程会处于处理任务的活动状态。如果在所有线程处于活动状态时提交附加任务,则在有可用线程之前,附加任务将在队列中等待。如果在关闭前的执行期间由于失败而导致任何线程终止,那么一个新线程将代替它执行后续的任务(如果需要)。在某个线程被显式地关闭之前,池中的线程将一直存在。

创建方法:

  1. java.util.concurrent.Executors.newFixedThreadPool(int nThreads)
  2.  
  3. or
  4.  
  5. java.util.concurrent.Executors.newFixedThreadPool(int nThreads, ThreadFactory threadFactory)

调用上面2个方法得到的对象为:ExecutorService

JDK自带的例子:

下面给出了一个网络服务的简单结构,这里线程池中的线程作为传入的请求。它使用了预先配置的 Executors.newFixedThreadPool(int) 工厂方法:

  1. class NetworkService implements Runnable {
  2. private final ServerSocket serverSocket;
  3. private final ExecutorService pool;
  4.  
  5. public NetworkService(int port, int poolSize) throws IOException {
  6. serverSocket = new ServerSocket(port);
  7. pool = Executors.newFixedThreadPool(poolSize);
  8. }
  9.  
  10. public void run() { // run the service
  11. try {
  12. for (;;) {
  13. pool.execute(new Handler(serverSocket.accept()));
  14. }
  15. } catch (IOException ex) {
  16. pool.shutdown();
  17. }
  18. }
  19. }
  20.  
  21. class Handler implements Runnable {
  22. private final Socket socket;
  23. Handler(Socket socket) { this.socket = socket; }
  24. public void run() {
  25. // read and service request on socket
  26. }
  27. }

主要的方法:

 
boolean awaitTermination(long timeout, TimeUnit unit)
请求关闭、发生超时或者当前线程中断,无论哪一个首先发生之后,都将导致阻塞,直到所有任务完成执行。
<T> List<Future<T>>  invokeAll(Collection<? extends Callable<T>> tasks)
执行给定的任务,当所有任务完成时,返回保持任务状态和结果的 Future 列表。
<T> List<Future<T>>
invokeAll(Collection<? extends Callable<T>> tasks,
long timeout, TimeUnit unit)


执行给定的任务,当所有任务完成或超时期满时(无论哪个首先发生),返回保持任务状态和结果的 Future 列表。
<T>
T
invokeAny(Collection<? extends Callable<T>> tasks)

执行给定的任务,如果某个任务已成功完成(也就是未抛出异常),则返回其结果。
<T>
T
invokeAny(Collection<? extends Callable<T>> tasks,
long timeout, TimeUnit unit)


执行给定的任务,如果在给定的超时期满前某个任务已成功完成(也就是未抛出异常),则返回其结果。
boolean isShutdown()

如果此执行程序已关闭,则返回 true
boolean isTerminated()

如果关闭后所有任务都已完成,则返回 true
void shutdown()

启动一次顺序关闭,执行以前提交的任务,但不接受新任务。
List<Runnable> shutdownNow()

试图停止所有正在执行的活动任务,暂停处理正在等待的任务,并返回等待执行的任务列表。
<T> Future<T>
submit(Callable<T> task)

提交一个返回值的任务用于执行,返回一个表示任务的未决结果的 Future。
Future<?> submit(Runnable task)

提交一个 Runnable 任务用于执行,并返回一个表示该任务的 Future。
<T> Future<T>

submit(Runnable task, T result)

提交一个 Runnable 任务用于执行,并返回一个表示该任务的
Future。

void

execute(Runnable command)
在未来某个时间执行给定的命令。

自己写的例子:

  1. package com.yzl;
  2.  
  3. import java.util.Random;
  4. import java.util.concurrent.Callable;
  5. import java.util.concurrent.ExecutorService;
  6. import java.util.concurrent.Executors;
  7. import java.util.concurrent.Future;
  8. import java.util.concurrent.TimeUnit;
  9.  
  10. public class ThreadPool {
  11. public static void main(String[] args) {
  12. fixedThreadPool();
  13. }
  14.  
  15. /**
  16. * 固定大小的线程池
  17. *
  18. * 同时可以处理【参数】个任务,多余的任务会排队,当处理完一个马上就会去接着处理排队中的任务。
  19. * Callable的任务在后面的blog有更详细的文章说明
  20. */
  21. private static void fixedThreadPool(){
  22. ExecutorService es = Executors.newFixedThreadPool(2);
  23. //加入5个任务
  24. for(int i=1 ; i<5; i++){
  25. final int task = i;
  26. es.execute(new Runnable() {
  27. @Override
  28. public void run() {
  29. for(int j=1; j<=2; j++){
  30. System.out.println("现在运行的是第【 " + task + "】任务");
  31. System.out.println(Thread.currentThread().getName() + "is work , now loop to " + j);
  32. if(j==2){
  33. System.out.println("任务 【" + task + "】运行完成");
  34. }
  35. try {
  36. Thread.sleep(100);
  37. } catch (InterruptedException e) {
  38. e.printStackTrace();
  39. }
  40. }
  41. }
  42. });
  43. }
  44. System.out.println("5个Runnable任务submit完成!!");
  45.  
  46. //加入5个Callable任务,该任务执行完后是有返回值的则会发生堵塞,也就是取到5个任务的结果后才会继续往下走
  47. for(int i=1 ; i<=5; i++){
  48. final int task = i;
  49. Future<Integer> future = es.submit(new Callable<Integer>() {
  50. @Override
  51. public Integer call() throws Exception {
  52. try {
  53. Thread.sleep(100);
  54. } catch (InterruptedException e) {
  55. e.printStackTrace();
  56. }
  57. System.out.println("Callable 任务【" + task + "】运行");
  58. return new Random().nextInt(100);
  59. }
  60. });
  61.  
  62. //如果注释取结果的代码,则不会堵塞
  63. /*try {
  64. System.out.println("任务【" + i + "】返回的结果:" + future.get());
  65. } catch (Exception e) {
  66. e.printStackTrace();
  67. }*/
  68. }
  69. System.out.println("5个Callable任务submit完成!!" + System.currentTimeMillis() );
  70. //虽然shutdown方法是等所有任务跑完后才真正停掉线程池,但该方法不会造成堵塞,也就是这代码运行后,下一行代码会立刻运行
  71. es.shutdown();
  72. System.out.println("主程序shutdown后退出!!" + System.currentTimeMillis());
  73.  
  74. //暴力的直接终止线程池
  75. //es.shutdownNow();
  76.  
  77. //awaitTermination方法是堵塞式的,只有等真的把线程池停掉才会让程序继续往下执行
  78. try {
  79. es.awaitTermination(2, TimeUnit.SECONDS);
  80. } catch (InterruptedException e) {
  81. e.printStackTrace();
  82. }
  83.  
  84. System.out.println("主程序后awaitTermination退出!!" + System.currentTimeMillis());
  85. }
  86. }

6、java5线程池之固定大小线程池newFixedThreadPool的更多相关文章

  1. ExecutorService常用方法和newFixedThreadPool创建固定大小的线程池

    1.ExecutorService: 是一个接口,继承了Executor: public interface ExecutorService extends Executor { } 2.Execut ...

  2. 8、java5线程池之动态缓存线程池newCachedThreadPool

    JDK文档描述 创建一个可根据需要创建新线程的线程池,但是在以前构造的线程可用时将重用它们.对于执行很多短期异步任务的程序而言,这些线程池通常可提高程序性能.调用 execute 将重用以前构造的线程 ...

  3. 线程池系列一:线程池作用及Executors方法讲解

    线程池的作用: 线程池作用就是限制系统中执行线程的数量.     根据系统的环境情况,可以自动或手动设置线程数量,达到运行的最佳效果:少了浪费了系统资源,多了造成系统拥挤效率不高.用线程池控制线程数量 ...

  4. 【转】线程及同步的性能 - 线程池 / ThreadPoolExecutors / ForkJoinPool

    线程池和ThreadPoolExecutors 虽然在程序中可以直接使用Thread类型来进行线程操作,但是更多的情况是使用线程池,尤其是在Java EE应用服务器中,一般会使用若干个线程池来处理来自 ...

  5. java多线程系类:JUC线程池:03之线程池原理(二)(转)

    概要 在前面一章"Java多线程系列--"JUC线程池"02之 线程池原理(一)"中介绍了线程池的数据结构,本章会通过分析线程池的源码,对线程池进行说明.内容包 ...

  6. java多线程系类:JUC线程池:02之线程池原理(一)

    在上一章"Java多线程系列--"JUC线程池"01之 线程池架构"中,我们了解了线程池的架构.线程池的实现类是ThreadPoolExecutor类.本章,我 ...

  7. java多线程系类:JUC线程池:01之线程池架构

    概要 前面分别介绍了"Java多线程基础"."JUC原子类"和"JUC锁".本章介绍JUC的最后一部分的内容--线程池.内容包括:线程池架构 ...

  8. 线程及同步的性能 – 线程池/ ThreadPoolExecutors/ ForkJoinPool

    线程池和ThreadPoolExecutors 虽然在程序中可以直接使用Thread类型来进行线程操作,但是更多的情况是使用线程池,尤其是在Java EE应用服务器中,一般会使用若干个线程池来处理来自 ...

  9. 线程池;java的线程池的实现原理;适用于频繁互动(如电商网站)

    线程池是一种多线程处理形式,处理过程中将任务加入到队列,然后在创建线程后自己主动启动这些任务.线程池线程都是后台线程.每一个线程都使用默认的堆栈大小,以默认的优先级执行.并处于多线程单元中. 假设某个 ...

随机推荐

  1. .NetCore中EFCore for MySql整理

    一.MySql官方提供了Ef Core对MySql的支持,但现在还处于预览版 Install-Package MySql.Data.EntityFrameworkCore -Pre Install-P ...

  2. Arcgis ArcMap 10 如何生成msd地图文档定义【 arcgis mxd怎么转换成msd】

    .mxd是arcgis 的地图文档后缀名. .msd是arcgis 的地图服务定义文件,是 map service definition 的缩写. 基于 MSD 的服务支持 Maplex.制图表达和新 ...

  3. GAN与NLP的讨论

    https://www.jianshu.com/p/32e164883eab 这篇文章,GAN与NLP的讨论,可以看看.

  4. javascript中的分支判断与循环

    分支判断与循环 分支结构 单一选择结构(if) 二路选择结构(if/else) 内联三元运算符 ?: 多路选择结构(switch) var condition = true; if (conditio ...

  5. lync2013 错误: 已为不同的传输层安全性(TLS)目标找到类型为“McxInternal”且完全限定的域名(FQDN)为

    最近 练习安装lync2013 在发布拓扑结构时遇到如下错误: lync 错误: 已为不同的传输层安全性(TLS)目标找到类型为“McxInternal”且完全限定的域名(FQDN)为“lync.co ...

  6. 【Scala】Scala-使用ExecutorService-等待所有线程完成

    Scala-使用ExecutorService-等待所有线程完成 scala ExecutorService 等待_百度搜索 使用ExecutorService,如何等待所有线程完成,?_java_帮 ...

  7. xgboost入门与实战(实战调参篇)

    https://blog.csdn.net/sb19931201/article/details/52577592 xgboost入门与实战(实战调参篇) 前言 前面几篇博文都在学习原理知识,是时候上 ...

  8. LTR之RankSvm

    两种对比: 1.深度学习CNN提特征+RankSVM 之前的博客:http://www.cnblogs.com/bentuwuying/p/6681943.html中简单介绍了Learning to ...

  9. mahout安装

    mahout是hadoop的一种高级应用.运行mahout需要提前安装好hadoop.hadoop的安装网上很多.而且也不复杂,这里不再讲述.这里默认hadoop已经安装完成. 1:下载二进制解压安装 ...

  10. create-react-app时registry的奇怪问题

    用React官方给的NPM脚本 create-react-app my-app 在自动安装module的过程中,在安装registry的组件的时候莫名其妙的挂住不动了.界面显示的信息如下: fetch ...