什么是java线程池
1、什么是线程池: java.util.concurrent.Executors提供了一个 java.util.concurrent.Executor接口的实现用于创建线程池。
2、java线程池的实现原理很简单,说白了就是一个线程集合workerSet和一个阻塞队列workQueue。当用户向线程池提交一个任务(也就是线程)时,线程池会先将任务放入workQueue中。
3、即在没有任务到来之前就创建 corePoolSize 个线程或者一个线程。
4、否则进入等待队列。Java里面线程池的顶级接口是Executor,但是严格意义上讲Executor并不是一个线程池,而只是一个执行线程的工具。真正的线程池接口是ExecutorService。ThreadPoolExecutor是Executors类的底层实现。
5、里面的线程叫工作线程 第一:降低资源消耗。通过重复利用已创建的线程降低线程创建和销毁造成的消耗。第二:提高响应速度。当任务到达时,任务可以不需要等到线程创建就能立即执行。第三:提高线程的可管理性。
线程池的参数有哪些
线程池七大核心参数是corePoolSize、maximumPoolSize、KeepAliveTime、unit、workQueue、threadFactory、handler。
线程池七大核心参数如下:corePoolSize核心线程数目-池中会保留的最多线程数。maximumPoolSize最大线程数目-核心线程+救急线程的最大数目。
ThreadPoolExecutor的重要参数 corePoolSize:核心线程数 maxPoolSize:最大线程数 当核心线程与任务队列已满时线程池会创建新线程处理任务。当线程数达到maxPoolSize后会拒绝线程抛出异常。
线程池七大核心参数
线程池七大核心参数是corePoolSize、maximumPoolSize、KeepAliveTime、unit、workQueue、threadFactory、handler。
线程池七大核心参数如下:corePoolSize核心线程数目-池中会保留的最多线程数。maximumPoolSize最大线程数目-核心线程+救急线程的最大数目。
池中的最大线程数。long keepAliveTime 当线程的数量大于corePoolSize,这是多余空闲线程的最大存活时间,当空间时间达到keepAliveTime值时,多余的线程会被销毁并等待新任务。
A.ThreadPoolExecutor的重要参数 corePoolSize:核心线程数 核心线程会一直存活,及时没有任务需要执行。当线程数小于核心线程数时,即使有线程空闲,线程池也会优先创建新线程处理。