ThreadPoolExecutor线程池的示例分析

技术ThreadPoolExecutor线程池的示例分析小编给大家分享一下ThreadPoolExecutor线程池的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获

是范仲淹还是范仲淹线程池执行程序朱庇特谢尼德谢尼德,不,不,不,不,不,不,不,不,不,不,不,不,不,不,不,不,不,不,不,不,不,不,不,不,不,不,不,不,不,不,不,不,不,不,不,不,不,不,不,不,你是说.-你好-你好,范仲淹是范仲淹还是范仲淹!

线程池参数

线程池执行程序范国泰范国泰范国泰,你是说.(嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨嗨):

/**

*创建一个新的{ @ codethreads poolexecutor }并从第九个开始

*参数。

*

* @ paramcorepolsizethnumberfthread stoeepinthepool,甚至

*如果空闲,除非{ @ codeallowcorethread超时}是一个

* @ paramaximummpolsixtmaximumromingstorallowin

*池

* @ paramckeepalivetimenumberfthreftssisse大于

*核心,这是一个复杂的线程

*将等待新任务开始.

{ @ codekeepalivetime }的* @ paramunitetimeunit参数

* @ paramworkquequequequeueefrooftrhodintaskssborestyare

*执行此问题将保持{ @代码可运行}

* tasksesebmi tdbyte { @ code execute }方法。

* @ param线程工厂工厂wheetly performer(执行程式)

*createsanewthread

* @ parametehandlerstouwhenexequation被锁定-参数处理程式图征处理程式图征处理程式图征处理程式图征处理程式图征处理程式图征处理程式图征处理程式图征处理程式图征处理程式图征处理程式图征处理程式图征

*由于边界和电容的限制

* @抛出非法

ArgumentException if one of the following holds:<br>
 *         {@code corePoolSize < 0}<br>
 *         {@code keepAliveTime < 0}<br>
 *         {@code maximumPoolSize <= 0}<br>
 *         {@code maximumPoolSize < corePoolSize}
 * @throws NullPointerException if {@code workQueue}
 *         or {@code threadFactory} or {@code handler} is null
 */
public ThreadPoolExecutor(int corePoolSize,
                          int maximumPoolSize,
                          long keepAliveTime,
                          TimeUnit unit,
                          BlockingQueue<Runnable> workQueue,
                          ThreadFactory threadFactory,
                          RejectedExecutionHandler handler) {
    if (corePoolSize < 0 ||
        maximumPoolSize <= 0 ||
        maximumPoolSize < corePoolSize ||
        keepAliveTime < 0)
        throw new IllegalArgumentException();
    if (workQueue == null || threadFactory == null || handler == null)
        throw new NullPointerException();
    this.corePoolSize = corePoolSize;
    this.maximumPoolSize = maximumPoolSize;
    this.workQueue = workQueue;
    this.keepAliveTime = unit.toNanos(keepAliveTime);
    this.threadFactory = threadFactory;
    this.handler = handler;
}

其实从构造方法的注释中,我们就能知道每个参数的意思:

  • corePoolSize:保留在线程池中的线程数量,即使它们是闲置的,除非allowCoreThreadTimeOut被设置。

  • maximumPoolSize:线程池允许的最大线程数。

  • keepAliveTime:当线程数大于corePoolSize时,那些额外的空闲线程在停止前等待新任务的最大时间。

  • unit:keepAliveTime参数的时间单位。

  • workQueue:在任务执行之前,用于保存任务的队列,队列只会保存那些使用execute方法提交的可执行的任务。

  • threadFactory:当线程池创建一个新线程时所用到的工厂。

  • handler:当任务的执行因为线程数量和队列容量到达边界而被阻止时,所调用的handler。

线程池工作原理

当一个新任务被提交时:

  1. 当前活跃线程数<corePoolSize,则创建一个新线程执行新任务;

  2. 当前活跃线程数>corePoolSize,且队列(workQueue)未满时,则将新任务放入队列中;

  3. 当前活跃线程数>corePoolSize,且队列(workQueue)已满,且当前活跃线程数<maximumPoolSize,则继续创建一个新线程执行新任务;

  4. 当前活跃线程数>corePoolSize,且队列(workQueue)已满,且当前活跃线程数=maximumPoolSize,则执行拒绝策略(handler);

当任务执行完成后:

  1. 超出corePoolSize的空闲线程,在等待新任务时,如果超出了keepAliveTime,则线程会被销毁;

  2. 如果allowCoreThreadTimeOut被设置为true,那么corePoolSize以内的空闲线程,如果超出了keepAliveTime,则同样会被销毁。

线程池队列

通过构造方法可以知道,workQueue参数是BlockingQueue<Runnable>类型的,而BlockingQueue是JUC包里的一个接口,其实现有:

ThreadPoolExecutor线程池的示例分析

其中,常用的队列如下:

  1. ArrayBlockingQueue:规定大小的BlockingQueue,其构造必须指定大小。其所含的对象是FIFO顺序排序的。

  2. LinkedBlockingQueue:大小不固定的BlockingQueue,若其构造时指定大小,生成的BlockingQueue有大小限制,不指定大小,其大小有Integer.MAX_VALUE来决定。其所含的对象是FIFO顺序排序的。

  3. PriorityBlockingQueue:类似于LinkedBlockingQueue,但是其所含对象的排序不是FIFO,而是依据对象的自然顺序或者构造函数的Comparator决定。

  4. SynchronizedQueue:特殊的BlockingQueue,对其的操作必须是放和取交替完成。

线程池拒绝策略

同样,通过构造方法可以知道,handler参数是RejectedExecutionHandler类型的,而RejectedExecutionHandler同样是JUC包里的一个接口,其实现有:

ThreadPoolExecutor线程池的示例分析

  1. DiscardOldestPolicy:丢掉缓存在队列中的最早的任务,然后重新尝试运行新任务。

  2. AbortPolicy:直接拒绝添加新任务,并抛出异常。

  3. CallerRunsPolicy:使用当前线程执行该任务,而不是使用线程池中的线程。

  4. DiscardPolicy:删除提交的新任务 。

以上是“ThreadPoolExecutor线程池的示例分析”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注行业资讯频道!

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/98522.html

(0)

相关推荐

  • Flex应用的误区有哪些

    技术Flex应用的误区有哪些这篇文章给大家分享的是有关Flex应用的误区有哪些的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。Flex应用的十大误区1.使用RIA框架去构建Web1.0应用(新技

    攻略 2021年12月4日
  • 抖音刷评论,抖音刷评论会被限流吗?

    技术抖音刷评论,抖音刷评论会被限流吗?抖音运营目前已经进入了新的发展阶段,抖音用户逐渐多了起来,同时抖音上的管理也越来越严格,小伙伴在刷粉的时候会是担心自己的账号会不会被限流,今天我们就来了解以下抖音刷赞,抖音刷评论。

    测评 2021年11月10日
  • Percona 5.5如何定位未使用的索引

    技术Percona 5.5如何定位未使用的索引这篇文章主要为大家展示了“Percona 5.5如何定位未使用的索引”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Percona

    攻略 2021年11月2日
  • Linux下如何查看mysql的历史操作记录

    技术Linux下如何查看mysql的历史操作记录这篇文章主要介绍了Linux下如何查看mysql的历史操作记录,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下

    攻略 2021年10月30日
  • 农村医保网上如何缴费,怎么在网上给农村合作医疗缴费

    技术农村医保网上如何缴费,怎么在网上给农村合作医疗缴费可以用建设银行APP农村医保网上如何缴费,登录医保缴费,进行缴纳。1、打开建设银行APP,点击页面左上角箭头指的的地方。登录个人账户。2、点击右下角“悦享生活”。3、

    生活 2021年10月30日
  • 按照防火墙对数据的处理方法可将防火墙分为什么

    技术按照防火墙对数据的处理方法可将防火墙分为什么本篇内容主要讲解“按照防火墙对数据的处理方法可将防火墙分为什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“按照防火墙对数据的

    攻略 2021年11月9日