线程池怎么实现的,核心参数讲一讲?

Executors是线程池的工厂类,通过调用它的静态方法如下:

Executors.newCachedThreadPool();
Executors.newFixedThreadPool();

可返回一个线程池。这些静态方法统一返回一个ThreadPoolExecutor,只是参数不同。

public ThreadPoolExecutor
(int corePoolSize,
int maximumPoolSize,
long keepAliveTime,
TimeUnit unit,
BlockingQueue<Runnaable> workQueue,
ThreadFactory threadFactory,
RejectedExecutionHandler handler){}

1、corePoolSize:指定了线程池中线程的数量

2、maximumPoolSize:线程池中的最大线程数量

3、keepAliveTime:当线程池中线程数量超过corePoolSize时,多余的空闲线程的存活时间

4、unit:上一个参数keepAliveTime的单位

5、任务队列:被提交还未被执行的任务

6、threadFactory:线程工厂,用于创建线程,一般默认工厂即可

7、handler:拒绝策略,当任务太多来不及处理,采用什么方法拒绝任务

最重要的是任务队列和拒绝策略

任务队列主要有ArrayBlockingQueue有界队列、LinkedBlockingQueue无界队列、SynchronousQueue直接提交队列。

1、ArrayBlockingQueue:

当线程池中实际线程数小于核心线程数时,直接创建线程执行任务;

当大于核心线程数而小于最大线程数时,提交到任务队列中;

因为这个队列是有界的,当队列满时,在不大于最大线程的前提下,创建线程执行任务;

若大于最大线程数,执行拒绝策略。

2、LinkedBlockingQueue:

当线程池中实际线程数小于核心线程数时,直接创建线程执行任务;

当大于核心线程数而小于最大线程数时,提交到任务队列中;

因为这个队列是无界的,所以之后提交的任务都会进入任务队列中。

newFixedThreadPool就采用了无界队列,同时指定核心线程和最大线程数一样。

3、SynchronousQueue:

该队列没有容量,对提交任务不做保存,直接增加新线程来执行任务。

newCachedThreadPool使用的是直接提交队列,核心线程数是0,最大线程数是整型的最大值,

keepAliveTime是60s,因此当新任务提交时,若没有空闲线程都是新增线程来执行任务,

不过由于核心线程数是0,当60s就会回收空闲线程。

当线程池中的线程达到最大线程数时,就要开始执行拒绝策略了,如下:

1、直接抛出异常

2、在调用者的线程中,运行当前任务

3、丢弃队列最近的一个任务,也就是将队列头的任务poll出去

4、默默丢弃无法处理的任务,不做任何处理

Java线程池使用和常用参数(待续)的更多相关文章

  1. Java线程池使用和常用参数

    多线程问题: 1.java中为什么要使用多线程使用多线程,可以把一些大任务分解成多个小任务来执行,多个小任务之间互不影像,同时进行,这样,充分利用了cpu资源. 2.java中简单的实现多线程的方式 ...

  2. java线程池和五种常用线程池的策略使用与解析

    java线程池和五种常用线程池策略使用与解析 一.线程池 关于为什么要使用线程池久不赘述了,首先看一下java中作为线程池Executor底层实现类的ThredPoolExecutor的构造函数 pu ...

  3. java线程池与五种常用线程池策略使用与解析

    背景:面试中会要求对5中线程池作分析.所以要熟知线程池的运行细节,如CachedThreadPool会引发oom吗? java线程池与五种常用线程池策略使用与解析 可选择的阻塞队列BlockingQu ...

  4. Java线程池参数

    关于Java线程池的参数设置.线程池是Java多线程里开发里的重要内容,使用难度不大,但如何用好就要明白参数的含义和如何去设置.干货里的内容大多是参考别人的,加入了一些知识点的扩充和看法.希望能对多线 ...

  5. Java线程池七个参数详解

    Java多线程开发时,常常用到线程池技术,这篇文章是对创建java线程池时的七个参数的详细解释. 从源码中可以看出,线程池的构造函数有7个参数,分别是corePoolSize.maximumPoolS ...

  6. Java线程池使用说明

    Java线程池使用说明 转自:http://blog.csdn.net/sd0902/article/details/8395677 一简介 线程的使用在java中占有极其重要的地位,在jdk1.4极 ...

  7. 四种Java线程池用法解析

    本文为大家分析四种Java线程池用法,供大家参考,具体内容如下 http://www.jb51.net/article/81843.htm 1.new Thread的弊端 执行一个异步任务你还只是如下 ...

  8. [转 ]-- Java线程池使用说明

    Java线程池使用说明 原文地址:http://blog.csdn.net/sd0902/article/details/8395677 一简介 线程的使用在java中占有极其重要的地位,在jdk1. ...

  9. java线程池的使用与详解

    java线程池的使用与详解 [转载]本文转载自两篇博文:  1.Java并发编程:线程池的使用:http://www.cnblogs.com/dolphin0520/p/3932921.html   ...

随机推荐

  1. at org.codehaus.jackson.map.ser.BeanSerializer.serialize(BeanSerializer.java:142) :json转化“$ref 循环引用”的问题

    原因: entity实体中存在@OneToMany,@ManyToOne注解,在转化json是产生了循环引用 报的错误 解决方法: springmvc @ResponseBody 默认的json转化用 ...

  2. Vue.js随笔四(方法的声明和使用)

    1.首先你需要新建路由,这个就不多说了 2.然后在你的新的.vue里面需要如下所示的添加methods:{方法},然后按钮的里面你会看到v-on:click,这就是点击这个按钮会触发的动作,这个就是触 ...

  3. flex属性设置详解

    CSS代码中常见这样的写法:flex:1 这是flex 的缩写: flex-grow.flex-shrink.flex-basis,其取值可以考虑以下情况: 1. flex 的默认值是以上三个属性值的 ...

  4. CentOS下安装JDK1.8

    0.卸载旧版本 键入命令java-version,查询当前JDK版本 如果版本号不是想要的,键入rpm -qa|grep gcj 键入命令 yum -y remove (后接查询得到的版本),移除老版 ...

  5. poi复杂excel的实现

    一:前言 最近帮一个朋友做excel的导出功能,对于我来说还是挺头疼,我看了下表格样式,对于我来说还是挺头疼的,想当年耗子刚刚出社会的时候做的第一份工作,第一份任务就是把把word转换为html,在这 ...

  6. Uva5211/POJ1873 The Fortified Forest 凸包

    LINK 题意:给出点集,每个点有个价值v和长度l,问把其中几个点取掉,用这几个点的长度能把剩下的点围住,要求剩下的点价值和最大,拿掉的点最少且剩余长度最长. 思路:1999WF中的水题.考虑到其点的 ...

  7. CSS居中之美

    关于居中,你会想到什么? div{margin: auto;} 常见的居中方法 水平居中 .demo{ text-align: center; margin: auto; position: abso ...

  8. 给你灵感!21个精美的 iOS APP 网站设计欣赏

    iOS 吹起了轰轰烈烈的扁平化设计风格,而做为承载 App 宣传重任的网页,整体设计风格的变迁如何?是否也如iOS的设计风格改革一样彻底的翻转?还是如往常一直深耕成熟的设计风格? Spendee Fo ...

  9. CSS浏览器兼容问题集-第二部分

    11.高度不适应 高度不适应是当内层对象的高度发生变化时外层高度不能自动进行调节,特别是当内层对象使用margin 或paddign 时.   例:  #box {background-color:# ...

  10. Lua的工具资源3

    [LuaSrcDiet] (5.0.2) - 通过删除不必要的空白和注释缩减Lua文件的大小. [LuaProfiler] (5.0) - 一个用来查找Lua应用瓶颈的工具time profiler ...