两个好处:
1、线程可以重复利用,不用对同步任务进行不断的创建销毁
2、可以限制和管理资源,如线程
两个结果组成:
Set workers 表示每个正在跑的线程,在run中,先是处理第一个Task,处理完后会从workQueue中尝试拿到一个Task进行处理,如果没有,结束(keepAliveTime可以调节结束的延时)、删除这个worker
BlockingQueue<Runnable> workQueue 表示poolSize快要超出corePoolSize的时候,将对象放到阻塞队列里面去。如果阻塞队列也放不进去,继续放入workSet集合里面,如果workset超出了maximumPoolSize,就只能RejectedExecutionHandler来处理
shutdown 如果这个worker空闲了(如果线程正在跑,会有runlock锁住,然后tryLock返回false,就表示该worker不是空闲状态),就interrupt这个worker对应的线程。(所以如果在run里面做死循环的话,可以保证不是空闲的)
shutdownNow就不tryLock,直接执行worker.thread.interrupt()
ThreadPoolExecutor状态
RUNNING 表示接受新任务,同时处理队列中已有的任务
SHUTDOWN(shutdown) 表示不接受新任务,但会等剩余任务(包括workqueue里面的任务)都运行完
STOP(shutdownnow) 表示不接受新任务,不处理队列中的任务,interrupt workers里面的所有线程
TERMINATE 表示所有的线程已经终止
Executors.newFixedThreadPool(int nThreads)
创建的时候corePoolSize和maximumPoolSize一样都是nThreads,queue为LinkedBlockingQueue。也就是说,如果workset放满了,就放到queue里面等待,如果queue也放满了(基本不会出现这种情况,没设值,默认为Integer.MAX_VALUE),就只能RejectExecutionHandler来处理。
Executors.newCachedThreadPool()
创建的时候corePoolSize为0,maximumPoolSize为Integer.MAX_VALUE,queue为SynchronousQueue。也就是说,先将任务放入queue里面,如果workset里面的poolsize为0,会在workset里面创建一个空任务去抓取SynchronousQueue里面的等待任务。如果不为0,就等待任务workset里面的某个任务先处理完了再去抓。如果有新任务进来,先判断是否能放入queue(这里是SynchronousQueue,只能放一个),如果不能,就直接放入workset里面。
两种线程池缺点:
fixedThreadPool会出现内存不可控制的情况,因为LinkedBlockingQueue没有数量限制。
cachedThreadPool更容易出现内存不可控制,因为maximumPoolSize为Integer.MAX_VALUE,很可能会创建许多线程(线程所占的内存比一个任务对象所占内存肯定大很多)。所以它适合于任务小,处理速度非常快的场景
相关推荐
1.资源简介:PyQt5中使用多线程模块QThread解决了PyQt5界面程序执行比较耗时操作时,程序卡顿出现的无响应以及界面输出无法实时显示的问题,采用线程池ThreadPoolExecutor解决了ping多个IP多任务耗时问题。...
线程池ThreadPoolExecutor实战及其原理分析(下)线程池ThreadPoolExecutor实战及其原理分析(下)线程池ThreadPoolExecutor实战及其原理分析(下)线程池ThreadPoolExecutor实战及其原理分析(下)线程池ThreadPoolExecutor...
线程池ThreadPoolExecutor底层原理源码分析
线程池ThreadPoolExecutor实战及其原理分析(上)
线程池ThreadPoolExecutor使用简介与方法实例 线程池ThreadPoolExecutor是Java并发编程中一个非常重要的概念,它允许开发者将任务提交给线程池,并由线程池来管理这些任务的执行。今天,我们将对线程池...
在《阿里巴巴java开发手册》中...另外由于前面几种方法内部也是通过ThreadPoolExecutor方式实现,使用ThreadPoolExecutor有助于大家明确线程池的运行规则,创建符合自己的业务场景需要的线程池,避免资源耗尽的风险。
从Python3.2开始,标准库为我们提供了 concurrent.futures 模块,它提供了 ThreadPoolExecutor (线程池)和ProcessPoolExecutor (进程池)两个类。 相比 threading 等模块,该模块通过 submit 返回的是一个 future ...
`ThreadPoolExecutor`是Java并发包`java.util.concurrent`中的核心类,用于实现线程池服务。通过设置线程池参数,我们可以定制线程池的行为,比如核心线程数、最大线程数、线程空闲时间等。 创建一个`...
### 线程池 `ThreadPoolExecutor` 原理源码分析 #### 一、概述 线程池作为 Java 并发编程中的重要组件,在实际应用中被广泛使用。其核心类 `ThreadPoolExecutor` 实现了对线程的管理、调度等功能。本文将围绕 `...
线程池是多线程编程中一种高效管理线程资源的方式,主要由Java的`ThreadPoolExecutor`类实现。线程池的工作机制在于控制线程数量,它会将任务放入队列,然后根据线程池的设定创建并启动线程执行这些任务。如果线程...
根据给定文件的信息,我们可以深入探讨Java中`ThreadPoolExecutor`线程池的底层实现原理,特别是其核心数据结构`ctl`以及线程池的各种状态转换。以下是对这些知识点的详细解释: ### 一、线程池`ThreadPoolExecutor...
这个类是Spring对Java内置的`java.util.concurrent.ThreadPoolExecutor`的封装,允许开发者在Spring应用上下文中声明式地定义线程池。在本篇文章中,我们将深入探讨`ThreadPoolTaskExecutor`的配置及其使用,并结合`...
根据提供的文件信息,我们可以深入探讨线程池`ThreadPoolExecutor`的工作原理及其实现细节,同时也会涉及并发编程中的一些关键概念和技术。 ### 线程池`ThreadPoolExecutor`概述 `ThreadPoolExecutor`是Java中非常...
Java线程池ThreadPoolExecutor原理及使用实例 Java线程池ThreadPoolExecutor是Java并发编程中的一种基本机制,主要用于管理和执行任务的线程池。下面对其原理和使用实例进行详细介绍。 线程池概述 线程池是一个...
Android中的线程池ThreadPoolExecutor解决了单线程下载数据的效率慢和线程阻塞的的问题,它的应用也是优化实现的方式。所以它的重要性不言而喻,但是它的复杂性也大,理解上可能会有问题,不过作为安卓工程师,了解...
ThreadPoolExecutor的使用和Android常见的4种线程池使用介绍
Spring线程池ThreadPoolExecutor配置并且得到任务执行的结果 在Java中,线程池是一种非常重要的技术,能够帮助我们更好地管理线程资源,提高系统的性能和可扩展性。其中,ThreadPoolExecutor是Java中的一种线程池...
11-线程池 ThreadPoolExecutor 底层原理源码分析(上)-周瑜.pdf 12-线程池 ThreadPoolExecutor底层原理源码分析(下)-周瑜.pdf 13、线程池 ForkJoinPool实战及其工作原理分析 (1).pdf 14、深入理解井发可见性、...
11-线程池 ThreadPoolExecutor 底层原理源码分析(上)-周瑜.pdf 12-线程池 ThreadPoolExecutor底层原理源码分析(下)-周瑜.pdf 13、线程池 ForkJoinPool实战及其工作原理分析 (1).pdf 14、深入理解井发可见性、...