头部左侧文字
头部右侧文字
当前位置:网站首页 > 资讯 > 正文

executors四种线程池的简单介绍

作者:admin日期:2024-01-10 19:45:10浏览:57分类:资讯

线程池使用及优势

线程池的优点 线程是稀缺资源,使用线程池可以减少创建和销毁线程的次数,每个工作线程都可以重复使用。可以根据系统的承受能力,调整线程池中工作线程的数量,防止因为消耗过多内存导致服务器崩溃。

maximumPoolSize (最大线程数大小):线程池允许创建的最大线程数,当队列已满,并且线程池中的线程数小于最大线程数,则线程池会创建新的线程执行任务。当使用无界队列时,此参数无用。

线程池是一种“池化”的线程使用模式,通过创建一定数量的线程,让这些线程处于就绪状态来提高系统响应速度,在线程使用完成后归还到线程池来达到重复利用的目标,从而降低系统资源的消耗。

线程池的四种创建方式及区别

newScheduedThreadPool 创建一个定长的线程池,而且支持定时的以及周期性的任务执行,支持定时及周期性任务执行。

ava通过Executors提供四种线程池,分别为:newCachedThreadPool创建一个可缓存线程池,如果线程池长度超过处理需要,可灵活回收空闲线程,若无可回收,则新建线程。

继承thread类 实现runnable接口 有返回值:callable接口 线程池 也可以说是三种方式,线程池是一种封装好的技术。实现callable接口会有一个泛型,这泛型即代表返回值的类型。重写call()方法,得到返回值。

线程池是一种常见的多线程并发处理技术,它可以在需要执行任务的时候为任务提供一个线程,从而避免了每次执行任务都需要创建一个新的线程的开销。线程池的创建方式有几种,其中最常见的是使用ThreadPoolExecutor类来创建线程池。

Java中4种线程池 Java通过Executors提供四种线程池,分别为:newCachedThreadPool创建一个可缓存线程池,如果线程池长度超过处理需要,可灵活回收空闲线程,若无可回收,则新建线程。

线程创建方式及优缺点 继承Thread类 实现Runnable接口实现Callable接口 线程池方式 优缺点 继承Thread类 优点 、代码简单 。缺点 、该类无法集成别的类。实现Runnable接口 优点 、继承其他类。

十五、线程池(六)自动创建线程池的弊端

1、这几种自动创建的线程池都存在风险,相比较而言,自己手动创建会更好,因为我们可以更加明确线程池的运行规则,不仅可以选择适合自己的线程数量,更可以在必要的时候拒绝新任务的提交,避免资源耗尽的风险。

2、优点 、代码简单 。缺点 、该类无法集成别的类。实现Runnable接口 优点 、继承其他类。同一实现该接口的实例可以共享资源。

3、线程池的优点 线程是稀缺资源,使用线程池可以减少创建和销毁线程的次数,每个工作线程都可以重复使用。可以根据系统的承受能力,调整线程池中工作线程的数量,防止因为消耗过多内存导致服务器崩溃。

4、线程池缓存技术允许线程重用以减少线程创建开销,或者当创建无限数量的线程时可以降低系统的可靠性。

合理使用线程池以及线程变量

1、线程池中通过 ctl 字段来表示线程池中的当前状态,主池控制状态 ctl 是 AtomicInteger 类型,包装了两个概念字段:workerCount 和 runState,workerCount 表示有效线程数,runState 表示是否正在运行、正在关闭等状态。

2、maxPoolSize:最大线程数 当核心线程与任务队列已满时线程池会创建新线程处理任务。当线程数达到maxPoolSize后会拒绝线程抛出异常。

3、所以产生线程总数不会超过线程池中线程的数目,而如果服务器不利用线程池来处理这些请求则线程总数为50000。一般线程池大小是远小于50000。所以利用线程池的服务器程序不会为了创建50000而在处理请求时浪费时间,从而提高效率。

暂无评论,来添加一个吧。

取消回复欢迎 发表评论: