使用默认的 thread factory创建ThreadPoolExecutor实例

public ThreadPoolExecutor(int corePoolSize,
int maximumPoolSize,
long keepAliveTime,
TimeUnit unit,
BlockingQueue<Runnable> workQueue,
RejectedExecutionHandler handler)

例子:

//创建阻塞队列
BlockingQueue<Runnable> blockQueue = new ArrayBlockingQueue<Runnable>(20);
ThreadPoolExecutor pool = new ThreadPoolExecutor(3,5,50,TimeUnit.MILLISECONDS,blockQueue);
pool.allowCoreThreadTimeOut(false);//默认false
Runnable task = new Runnable() {
@Override
public void run() {
log.info("{}正在运行", Thread.currentThread().getName());
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
};
pool.execute(task); pool.shutdown();

参数解释:

corePoolSize:线程池中的核心线程数

maximumPoolSize:线程池中的最大线程数

keepAliveTime:

  • 当allowCoreThreadTimeout=false(默认)时,超过corePool的线程空闲的时间达到了keepAliveTime时间时,这些线程会超时关闭,直到线程数=corePoolSize。因此,
  • corePool的线程数,是固定的且永久有效的。即,即使当前没有需要执行的任务,也依然存活
  • 当allowCoreThreadTimeout=true时,包含corePool线程的所有线程的空闲时间达到了keepAliveTime时间时,这些线程会超时关闭,直到线程数=0。因此,
  • 线程池中的线程数<指定的corePool线程数时,当有新任务来时,即使有空闲线程,也会优先创先新线程来处理该任务,直到线程数=指定的corePool线程数。

workQueue:

  • 保存由execute方法提交的Runnable任务。
  • 阻塞队列分类:
    • ArrayBlockingQueue:FIFO。
    • LinkedBlockingQueue:FIFO。Executors.newFixedThreadPool使用该阻塞队列
    • SynchronousQueue:不存储任务。Executors.newCachedThreadPool使用该阻塞队列。

执行顺序

当线程数<指定corePool线程数时,创建线程。

当线程数>=指定corePool线程数,且任务队列未满时,将任务放入workQueue。

当线程数>=指定corePool线程数,且任务队列已满时,

  • 若线程数 < maximumPoolSize,则,创建线程
  • 若线程数 = maximumPoolSize,则,执行下边的handler,默认AbortPolicy即抛出异常。

还有1种情况会执行下边的handler,即:当执行shutdown();后,新进来的任务,就会被拒绝,此时调用handler。

handler:(ThreadPoolExecutor类中的几个内部实)

  • AbortPolicy(默认):丢弃任务,抛出RejectedExecutionException异常
  • DiscardPolicy:也是丢弃任务,但不抛出异常
  • DiscardOldestPolicy:对被拒绝的任务(新来的)不抛弃,而是抛弃队列里面等待最久的一个任务,然后把该拒绝任务加到队列
  • CallerRunsPolicy:重试添加当前被拒绝的任务,他会自动重复调用 execute() 方法,直到成功。

---------------------------最后,说下关闭

shutdown():平滑地关闭

  • 不会立即终止线程池
  • 停止接收新任务,并等待执行已提交的任务。已提交的任务=一类是已经在执行的+另一类队列中还没执行的。
  • 如果是服务器的,则不调用shutdown方法,即一直执行。

shutdownNow():立即关闭

  • 立即终止线程池
  • 停止接收新任务,已提交的任务直接打断,并清空缓存队列
  • 返回尚未执行的任务列表(Runnable List)

线程池(1)ThreadPoolExecutor梳理的更多相关文章

  1. 从源码解读线程(Thread)和线程池(ThreadPoolExecutor)的状态

    线程是比进程更加轻量级的调度执行单位,理解线程是理解并发编程的不可或缺的一部分:而生产过程中不可能永远使用裸线程,需要线程池技术,线程池是管理和调度线程的资源池.因为前不久遇到了一个关于线程状态的问题 ...

  2. Java并发编程:Java线程池核心ThreadPoolExecutor的使用和原理分析

    目录 引出线程池 Executor框架 ThreadPoolExecutor详解 构造函数 重要的变量 线程池执行流程 任务队列workQueue 任务拒绝策略 线程池的关闭 ThreadPoolEx ...

  3. 线程池 一 ThreadPoolExecutor

    java.util.concurrent public class ThreadPoolExecutor extends AbstractExecutorService ThreadPoolExecu ...

  4. 线程池之 ThreadPoolExecutor

    线程池之 ThreadPoolExecutor + 面试题 线程池介绍 线程池(Thread Pool):把一个或多个线程通过统一的方式进行调度和重复使用的技术,避免了因为线程过多而带来使用上的开销. ...

  5. 高并发之——不得不说的线程池与ThreadPoolExecutor类浅析

    一.抛砖引玉 既然Java中支持以多线程的方式来执行相应的任务,但为什么在JDK1.5中又提供了线程池技术呢?这个问题大家自行脑补,多动脑,肯定没坏处,哈哈哈... 说起Java中的线程池技术,在很多 ...

  6. 【高并发】不得不说的线程池与ThreadPoolExecutor类浅析

    大家好,我是冰河~~ 今天,我们一起来简单聊聊线程池中的ThreadPoolExecutor类,好了,不多说了,开始进入今天的正题. 一.抛砖引玉 既然Java中支持以多线程的方式来执行相应的任务,但 ...

  7. 线程池:ThreadPoolExecutor源码解读

    目录 1 带着问题去阅读 1.1 线程池的线程复用原理 1.2 线程池如何管理线程 1.3 线程池配置的重要参数 1.4 shutdown()和shutdownNow()区别 1.5 线程池中的两个锁 ...

  8. 线程池:ThreadPoolExecutor

    [ThreadPoolExecutor的使用和思考]   public ThreadPoolExecutor(int corePoolSize,                             ...

  9. Java线程池之ThreadPoolExecutor

    前言 线程池可以提高程序的并发性能(当然是合适的情况下),因为对于没有线程的情况下,我们每一次提交任务都新建一个线程,这种方法存在不少缺陷: 1.  线程的创建和销毁的开销非常高,线程的创建需要时间, ...

  10. 从源码看JDK提供的线程池(ThreadPoolExecutor)

    一丶什么是线程池 (1)博主在听到线程池三个字的时候第一个想法就是数据库连接池,回忆一下,我们在学JavaWeb的时候怎么理解数据库连接池的,数据库创建连接和关闭连接是一个比较耗费资源的事情,对于那些 ...

随机推荐

  1. Unity-2017.2官方实例教程Roll-a-ball(二)

    声明: 本文系转载,由于Unity版本不同,文中有一些小的改动,原文地址:http://www.jianshu.com/p/97b630a23234 上一节Unity-2017.2官方实例教程Roll ...

  2. About getByClass

    不能获取class为多个的情况 function getByClass(parent,cls){ var res=[]; var ele=parent.getElementsByTagName(&qu ...

  3. ZJOI2012题解

    t1灾难 给一个食物网 如果一个生物吃的所有东西都灭绝了 它也跟着灭绝 求每个生物灭绝时跟着灭绝的生物数量 支配树裸题,我们先拓扑排序,然后建立一棵树满足一个点灭绝时,有且仅有它的子树跟着灭绝 考虑如 ...

  4. XML配置中 引入外部property文件

    新建properties配置文件 内容如下: jdbc.driverClassName=com.mysql.jdbc.Driver jdbc.url=jdbc\:mysql\://localhost\ ...

  5. ACM学习历程——POJ 2376 Cleaning Shifts(贪心)

    Description Farmer John is assigning some of his N (1 <= N <= 25,000) cows to do some cleaning ...

  6. ogg日常运维命令

    1.查看历史记录.快捷执行历史中的一条命令 GGSCI (11g) 32> h 23: view param exta24: info all25: lag exta.... GGSCI (11 ...

  7. Spring 3.1新特性之三:Spring对声明式缓存的支持

    一.概述: Spring 3.1 引入了激动人心的基于注释(annotation)的缓存(cache)技术,它本质上不是一个具体的缓存实现方案(例如EHCache 或者 OSCache),而是一个对缓 ...

  8. Java面试知识点总结(1)

    1.Java中的原始数据类型都有哪些,它们的大小及对应的封装类是什么? 原始数据类型 大小(byte) 对应封装类型 boolean 1或4 Boolean byte 1 Byte short 2 S ...

  9. linux下的函数dirname()和basename()使用

    总览 #include <libgen.h> char *dirname(char *path); char *basename(char *path); 说明 函数以 '/' 为分隔符 ...

  10. Ubuntu中的minicom

    需要更新一下软件源: sudo apt-get update 安装 在终端中输入sudo apt-get install minicom 配置 输入sudo minicom -s,注意前边一定要加su ...