zoukankan      html  css  js  c++  java
  • java线程池参数含义

    转载自 http://blog.csdn.net/zhouhl_cn/article/details/7392607 感谢分享

    项目中开发通常不会直接使用ThreadPoolExecutor,而是通过Executors.newFixedThreadPool()这种简易写法,创建适合自己项目的线程池。但是了解最基本的线程池ThreadPoolExecutor是十分必要的,尤其是做一些定制方法。比如在执行完一个线程任务后,进行后续操作,此时如果自己实现一个类继承自ThreadPoolExecutor

    public class PmCollectDataHandlePool extends ThreadPoolExecutor

    并且实现
    @Override
    protected void afterExecute(Runnable r, Throwable t) 是十分方便的做法

    一下参数来自转载
    • corePoolSize

    核心线程数,核心线程会一直存活,即使没有任务需要处理。当线程数小于核心线程数时,即使现有的线程空闲,线程池也会优先创建新线程来处理任务,而不是直接交给现有的线程处理。

    核心线程在allowCoreThreadTimeout被设置为true时会超时退出,默认情况下不会退出。

    • maxPoolSize
    当线程数大于或等于核心线程,且任务队列已满时,线程池会创建新的线程,直到线程数量达到maxPoolSize。如果线程数已等于maxPoolSize,且任务队列已满,则已超出线程池的处理能力,线程池会拒绝处理任务而抛出异常。
    • keepAliveTime

    当线程空闲时间达到keepAliveTime,该线程会退出,直到线程数量等于corePoolSize。如果allowCoreThreadTimeout设置为true,则所有线程均会退出直到线程数量为0。

    • allowCoreThreadTimeout

    是否允许核心线程空闲退出,默认值为false。

    • queueCapacity

    任务队列容量。从maxPoolSize的描述上可以看出,任务队列的容量会影响到线程的变化,因此任务队列的长度也需要恰当的设置。

    线程池按以下行为执行任务

    1. 当线程数小于核心线程数时,创建线程。
    2. 当线程数大于等于核心线程数,且任务队列未满时,将任务放入任务队列。
    3. 当线程数大于等于核心线程数,且任务队列已满
      1. 若线程数小于最大线程数,创建线程
      2. 若线程数等于最大线程数,抛出异常,拒绝任务
  • 相关阅读:
    linux在线书籍
    数据库使用记录(二)
    python读取配置文件报keyerror文件路径不正确导致的错误
    pycharm全局搜索快捷键无反应
    UVA 11054 Wine trading in Gergovia (Gergovia 的酒交易)(贪心+模拟)
    UVA 12107 Digit Puzzle(数字谜)(IDA*)
    UVA 12113 Overlapping Squares(重叠的正方形)
    UVA 10384 The Wall Pusher(推门游戏)(IDA*)
    UVA 11277 Cyclic Polygons(二分)
    【洛谷P2922】秘密消息【Trie】
  • 原文地址:https://www.cnblogs.com/juniorMa/p/5852170.html
Copyright © 2011-2022 走看看