1、线程池的创建
1、如果当前运行的线程少于corePoolSize,则创建新的线程来执行任务(注意:执行这一个步骤需要获取全局锁)
2、如果运行的线程等于或多于corePoolSize,则将任务加入BlockingQueue。
3、如果无法将任务加入BlockingQueue(队列已满),则创建新的线程来执行任务(注意:执行这一个步骤需要获取全局锁)
4、如果创建新的线程将使当前运行的线程超出maximunPoolSize,任务将会被拒绝,并且调用RejectedExecutionHandler.rejectExecution()方法。
2、线程池的关闭
可以通过线程池的shutdown
和shutdownNow
方法来关闭线程池。他们的原理是遍历线程池中的工作线程,然后逐个调用线程的interrupt方法来中断线程,所以无法响应中断的任务可能永远无法终止。
但是二者也存在一定的区别:
- shutdownNow首先将线程池的状态设为STOP,然后尝试停止所有的正在执行或者暂停任务的线程,并返回等待执行的任务的列表。
- shutdown只是将线程池的状态设置成SHUTDOWN状态,然后中断没有正在执行任务的线程。
主要调用了这二者中的任意一个,isShutdown方法就会返回True。当所有的任务都已经关闭之后,才表示线程池关闭成功,这时调用isTerminated方法就会反悔True。
至于要使用哪一个方法,应该由提交到线程池的任务特性来决定,通常采用shutdown方法来关闭线程池,如果任务不一定要执行完,则可以使用shutdownNow方法。
3、线程池的几个关键参数
- corePoolSize:线程池的基本大小
- runnableTaskQueue:任务队列
- ArrayBlockQueue:一个基于数组结构的有界阻塞队列,此队列按照FIFO原则对数据进行排序
- LinkedBlockingQueue:一个基于链表结构的阻塞队列
- SynchronizedQueue:一个不存储元素的阻塞队列
- PriorityBlockingQueue:一个具有优先级的无限阻塞队列
- maximumPoolSize:线程池的最大数量,即线程池允许创建的最大线程数
- ThreadFactory用于设置创建线程的工厂,可以通过线程工厂来给每个创建出来的线程设置更有意义的名字。
标签:知识点,复习,队列,创建,任务,线程,执行,方法 来源: https://www.cnblogs.com/yfwei/p/16541901.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。