文档章节

Java线程池ThreadPoolExecutor

JianF
 JianF
发布于 2016/08/09 11:29
字数 924
阅读 35
收藏 1

Java通过Executors提供四种线程池,分别为:

  1. Executors.newCachedThreadPool 创建一个可缓存线程池,如果线程池长度超过处理需要,可灵活回收空闲线程,若无可回收,则新建线程。
  2. Executors.newFixedThreadPool 创建一个定长线程池,可控制线程最大并发数,超出的线程会在队列中等待。
  3. Executors.newScheduledThreadPool 创建一个定长线程池,支持定时及周期性任务执行。
  4. Executors.newSingleThreadExecutor 创建一个单线程化的线程池,它只会用唯一的工作线程来执行任务,保证所有任务按照指定顺序(FIFO, LIFO, 优先级)执行。

ThreadPoolExecutor中定义了以下几个重要属性:

corePoolSize:池中所保存的线程数,包括空闲线程。 maximumPoolSize:线程池中的最大线程数量。 keepAliveTime : 当线程数大于核心时,此为终止前多余的空闲线程等待新任务的最长时间,超过corePoolSize的空闲线程,在多长时间内会被销毁。 TimeUnit unit:KeepAliveTime 参数的时间单位。 BlockingQueue<Runnable> workQueue:任务队列,被提交的但尚未被执行的任务。 workQueue主要有以下几种实现类型 1). SynchronousQueue:直接提交的队列,该队列没有容量,每一个擦入操作都要对应一个相应的删除操作,反之每个删除操作对应相应的插入操作。 SynchronousQueue不保存任务,它总是将任务提交给线程执行,如果没有空闲的进程,则尝试创建新的进程,如果进程已达到maximumPoolSize设置的最大线程数,则执行拒绝策略 2). ArrayBlockingQueue:有界任务队列,ArrayBlockingQueue的构造函数必须带一个容量参数(例如n),表示该队列的最大容量。当有新任务执行时,这个定义当前线程数为t,构造函数的容量参数为n,当前队列长度为l 1.t<corePoolSize时,创建新的线程之心 2.t>corePoolSize且l<n时,插入到任务队列,等待空闲线程执行 3.t>corePoolSize且l>=n时,创建新的线程执行新任务 4.t>maximumPoolSize时,执行拒绝策略。

3). LinkedBlockingQueue:无界任务队列,当有新任务执行时,如果线程池中线程数小于corePoolSize则创建新的线程,否则进入队列等待。如果没有任务创建速度和处理速度差异很大,无界队列会保持快速增长,直到耗尽系统内存 4). PriorityBlockingQueue: 优先级队列,可以控制任务的执行先后顺序,是一个特殊的无界队列。无论有界的队列无界的队列,都是按照先进先出算法处理任务(絮叨),而该队列破例可以根据任务自身的优先级顺序先后执行。

  1. ThreadFactory threadFactory//线程工厂,用于创建线程,一般默认
  2. RejectedExecutionHandler handler;//拒绝策略,当任务太多来不及处理,如何拒绝任务

JDK内置的拒绝策略如下:   AbortPolity策略:该策略会直接抛出异常,阻止系统正常工作   CallerRunsPolity策略:只要线程为关闭,该策略直接在调用者线程中,运行当前被丢弃的任务 DiscardOledstPolicy策略:该策略将丢弃最老的一个请求,也就是即将被执行的一个任务,并尝试再次提交当前任务。   DiscardPlicy 策略:该策略默默的丢弃无法处理的任务,不予任务处理。 如果以上策略不能满足实际应用需求,可以扩展RejectedExecutionHandler 接口 public interface RejectedExecutionHandler { void rejectedExecution(Runnable r, ThreadPoolExecutor executor); } 其中,r为请求执行的任务,executor为当前线程池。

本文转载自:

共有 人打赏支持
JianF
粉丝 5
博文 25
码字总数 11351
作品 0
通州
其他
私信 提问
Java多线程之线程池(ThreadPoolExecutor)实现原理分析(一)

在上一篇文章Java中实现多线程的3种方法介绍和比较中,我们讲解了Java中实现多线程的3种方法。使用多线程,就必须要考虑使用线程池,今天我们来聊聊线程池的那些事。 注:源码都是基于JDK1....

小怪聊职场
2018/05/14
0
0
Java线程框架_Executor

Executor 框架是 juc 里提供的线程池的实现。前两天看了下 Executor 框架的一些源码,做个简单的总结。 线程池大概的思路是维护一个的线程池用于执行提交的任务。我理解池的技术的主要意义有...

天呀鲁哇
2015/02/05
0
0
ThreadPoolExecutor源码分析及阻塞提交任务方法

ThreadPoolExecutor源码 ThreadPoolExecutor 基本使用参考:ThreadPoolExecutor执行过程分析 线程池状态标志 ctl 保存了线程池的运行状态(runState)和线程池内有效线程数量(workerCount)...

4rnold
2018/06/28
0
0
Java多线程学习(八)线程池与Executor 框架

Java面试通关手册(Java学习指南,欢迎Star,会一直完善下去,欢迎建议和指导):https://github.com/Snailclimb/JavaGuide 历史优质文章推荐: Java并发编程指南专栏 分布式系统的经典基础理...

snailclimb
2018/05/31
0
0
为何服务器QPS上不去?Java线程调优权威指南

从刚问世起,Java 的部分魅力就来自其多线程。即便在多核和多 CPU 系统司空见惯之前,能够轻松编写多线程程序也是 Java 的一个标志性特征。 Java 性能方面的吸引力显而易见:如果有两个 CPU ...

高可用架构
2016/05/13
0
0

没有更多内容

加载失败,请刷新页面

加载更多

Math-Model(二)-无向图最近邻路径搜索

%a=xlsread('../附件一:已结束项目任务数据.xls');clcclearGPS_1=importdata('../GPS_DATA.txt');GPS_2=importdata('../GPS_DATA2.txt');%X=min([min(GPS_1(:,1)),min(GPS_2(:,1))]):......

Pulsar-V
刚刚
0
0
react-navigation的学习

react-navigation的学习 react-navigation地址:https://reactnavigation.org/docs/en/navigating 导入的路由: import React from "react";import { View, Text } from "react-native";......

android-key
1分钟前
0
0
flume整合kafka,实现exactly one的数据采集

flume-kafka source配置 flume同步kafka的数据需要配置以下几个配置 type,数据源类型,如org.apache.flume.source.kafka.KafkaSource channels,下游对接source的channel名 topics,消费kaf...

厮以为
1分钟前
0
0
推荐:2019年十佳DevOps工具

DevOps落地重要的一方面是选好工具集,本文介绍了最流行的DevOps工具。 开发和运维的集成翻开了软件开发的全新篇章。如果你还是DevOps的新手,或者正在寻求改进已有流程的方法,那么第一道关...

架构师springboot
6分钟前
0
0
威胁预警|首现新型RDPMiner挖矿蠕虫 受害主机易被添加恶意账户

近日,阿里云安全发现一种新型挖矿蠕虫RDPMiner,通过爆破Windows Server 3389端口RDP服务的方式进行挖矿木马传播,致使用户CPU占用率暴涨,机器卡顿,更被创建名为DefaultAccount的账号。攻...

阿里云官方博客
6分钟前
0
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部