线程池-参数篇:2.队列
1、corePoolSize:核心线程数 maxPoolSize:最大线程数 当核心线程与任务队列已满时线程池会创建新线程处理任务。当线程数达到maxPoolSize后会拒绝线程抛出异常。
2、其中计算密集型阻塞系数为 0,IO 密集型阻塞系数接近 1,一般认为在 0.8 ~ 0.9 之间。比如 8 核 CPU,按照公式就是 2 / ( 1 – 0.9 ) = 20 个线程数 当线程数=corePoolSize,且任务队列已满时。
3、queueCapacity:任务队列容量(阻塞队列)当核心线程数达到最大时,新任务会放在队列中排队等待执行。maxPoolSize:最大线程数 当线程数=corePoolSize,且任务队列已满时。线程池会创建新线程来处理任务。
4、maximumPoolSize maximumPoolSize是线程池能够容纳同时执行的最大线程数。keepAliveTime keepAliveTime是多余的空闲线程存活时间。unit unit是keepAliveTime的时间单位。
线程池七大核心参数
1、线程池七大核心参数是corePoolSize、maximumPoolSize、KeepAliveTime、unit、workQueue、threadFactory、handler。
2、线程池七大核心参数如下:corePoolSize核心线程数目-池中会保留的最多线程数。maximumPoolSize最大线程数目-核心线程+救急线程的最大数目。
3、池中的最大线程数。long keepAliveTime 当线程的数量大于corePoolSize,这是多余空闲线程的最大存活时间,当空间时间达到keepAliveTime值时,多余的线程会被销毁并等待新任务。
4、ThreadPoolExecutor的重要参数 corePoolSize:核心线程数 maxPoolSize:最大线程数 当核心线程与任务队列已满时线程池会创建新线程处理任务。当线程数达到maxPoolSize后会拒绝线程抛出异常。
java常用的几种线程池实例讲解
newFixedThreadPool 创建一个指定工作线程数量的线程池。每当提交一个任务就创建一个工作线程,如果工作线程数量达到线程池初始的最大数,则将提交的任务存入到池队列中。
Java里面线程池的顶级接口是Executor,但是严格意义上讲Executor并不是一个线程池,而只是一个执行线程的工具。真正的线程池接口是ExecutorService。ThreadPoolExecutor是Executors类的底层实现。
java常用的线程池有三种:newFixedThreadPool public static ExecutorService newFixedThreadPool(int nThreads)创建一个可重用固定线程数的线程池,以共享的无界队列方式来运行这些线程。
首先说明下java线程是如何实现线程重用的 线程执行完一个Runnable的run()方法后,不会被杀死 当线程被重用时,这个线程会进入新Runnable对象的run()方法12 java线程池由Executors提供的几种静态方法创建线程池。
ava通过Executors提供四种线程池,分别为:newCachedThreadPool创建一个可缓存线程池,如果线程池长度超过处理需要,可灵活回收空闲线程,若无可回收,则新建线程。
如何设定线程池的大小
1、线程池需要设置合适的大小,假如设置的太大,线程上线文切换过于频繁,造成大量资源开销,反而会使性能降低。假如设置的太小,存在很多可用的处理器资源却未在工作,会造成资源的浪费和对吞吐量造成损失。
2、如果我们将这一比例称之为 WT/ST,那么对于一个具有 N 个处理器的系统,需要设置大约 N*(1+WT/ST) 个线程来保持处理器得到充分利用。处理器利用率不是调整线程池大小过程中的唯一考虑事项。
3、newCachedThreadPool:设定一个可缓存的线程池,当线程池长度超过处理的需要,可以灵活回收空闲线程,如果没有可以回收的才新建线程。没有核心线程数,当线程没有任务60s之后就会回收空闲线程,使用有界队列。