Java线程池的类型和使用

news/2025/2/19 17:02:46/

Java线程池的类型和使用

引言

在并发编程中,线程池是一种非常重要的工具,它可以实现线程的复用,避免频繁地创建新线程,从而提高程序的性能和效率。Java的并发库提供了丰富的线程池功能,本文将介绍Java线程池的类型和使用。

什么是线程池?

线程池是一种执行多个任务的并发模型。它由一个线程队列和一组可重用的线程组成,线程池中的线程可以并发地执行多个任务,避免了线程的频繁创建和销毁。

线程池的类型

Java提供了以下几种线程池类型:

1. FixedThreadPool

FixedThreadPool是一种固定大小的线程池,它会在初始化时创建指定数量的线程,并且在线程池的生命周期内始终保持该数量的线程。如果所有线程都处于忙碌状态,新任务将会等待执行。

ExecutorService executor = Executors.newFixedThreadPool(5);

2. CachedThreadPool

CachedThreadPool是一种无限大小的线程池,它会根据需要创建新的线程,并且在线程空闲一段时间后自动回收。当任务量较大时,会创建更多的线程来处理,当任务量较小时,会自动回收部分线程。

ExecutorService executor = Executors.newCachedThreadPool();

3. SingleThreadExecutor

SingleThreadExecutor是一种只有一个线程的线程池,它会按顺序执行所有任务。当该线程异常结束时,会创建一个新的线程继续执行剩余的任务。

ExecutorService executor = Executors.newSingleThreadExecutor();

4. ScheduledThreadPool

ScheduledThreadPool是一种定时执行任务的线程池。它可以在指定的延迟时间后执行任务,或者以固定的频率执行任务。

ScheduledExecutorService executor = Executors.newScheduledThreadPool(2);

线程池的使用

下面是一个使用FixedThreadPool线程池的示例代码:

import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;public class ThreadPoolExample {public static void main(String[] args) {ExecutorService executor = Executors.newFixedThreadPool(5);for (int i = 0; i < 10; i++) {final int taskId = i;executor.execute(new Runnable() {public void run() {System.out.println("Task " + taskId + " is being executed by " + Thread.currentThread().getName());}});}executor.shutdown();}
}

运行上述代码,输出如下:

Task 0 is being executed by pool-1-thread-1
Task 1 is being executed by pool-1-thread-2
Task 2 is being executed by pool-1-thread-3
Task 3 is being executed by pool-1-thread-4
Task 4 is being executed by pool-1-thread-5
Task 5 is being executed by pool-1-thread-1
Task 6 is being executed by pool-1-thread-2
Task 7 is being executed by pool-1-thread-3
Task 8 is being executed by pool-1-thread-4
Task 9 is being executed by pool-1-thread-5

上述示例中,我们使用了FixedThreadPool线程池,创建了一个固定大小为5的线程池。然后使用execute方法提交了10个任务给线程池执行。通过输出可以看到,线程池中的线程是被循环使用的。

线程池的原理

线程池的原理是通过创建一个线程池对象,该对象内部维护了一个线程队列和一组可重用的线程。当有任务提交给线程池时,线程池会从队列中获取一个空闲线程来执行任务,如果队列中没有空闲线程,且当前线程数少于线程池的最大线程数,则会创建一个新的线程。当任务执行完成后,线程会返回线程池,等待下一个任务的到来。

使用线程池的好处是避免了线程的频繁创建和销毁,同时可以控制并发线程的数量,避免资源的过度占用。

总结

本文介绍了Java线程池的类型和使用。通过固定大小的FixedThreadPool、无限大小的CachedThreadPool、单线程的SingleThreadExecutor以及定时任务的ScheduledThreadPool等不同类型的线程池,我们可以根据实际需求选择合适的线程池来提高程序的性能和效率。


http://www.ppmy.cn/news/1026429.html

相关文章

佛祖保佑,永不宕机,永无bug

当我们的程序编译通过&#xff0c;能预防的bug也都预防了&#xff0c;其它的就只能交给天意了。当然请求佛祖的保佑也是必不可少的。 下面是一些常用的保佑图&#xff1a; 佛祖保佑图 ——————————————————————————————————————————…

《贫穷的本质》阅读笔记

《贫穷的本质》阅读笔记 2023年8月11日在杭州小屋读完&#xff0c;对于穷&#xff0c;我可有太多想说的了。可以说自己活这么大以来&#xff0c;一直在摆脱贫穷&#xff0c;也将会穷尽一生去避免贫穷。作为一个穷人该如何去摆脱贫穷&#xff0c;我觉得没有一个确切的答案&#…

或许有用的开源项目平台——物联网、区块链、商城、CMS、客服系统、低代码、可视化、ERP等

摘自个人印象笔记Evernote Export wumei-smart-物美智能开源物联网平台 官网&#xff1a;https://wumei.live/ gitee&#xff1a;https://gitee.com/kerwincui/wumei-smart 一个简单易用的物联网平台。可用于搭建物联网平台以及二次开发和学习。适用于智能家居、智慧办公、智慧…

缓存穿透,击穿,雪崩之间的区别与联系

1、缓存数据基本流程 通常来说,我们是从数据库将数据查询出来之后,如果数据不为空,则将数据存储在缓存中,下次查询时就直接从缓存查询了,只有查询不到才会从数据库查询。 2、缓存穿透 核心在穿透两个字,穿透了,就说明在查询数据时没有遇到阻碍,直接就查询到了数据库。…

Spring与Spring Bean

Spring 原理 它是一个全面的、企业应用开发一站式的解决方案&#xff0c;贯穿表现层、业务层、持久层。但是 Spring 仍然可 以和其他的框架无缝整合。 Spring 特点 轻量级 控制反转 面向切面 容器 框架集合 Spring 核心组件 Spring 总共有十几个组件核心容器(Spring core) S…

安全之安全(security²)博客目录导读

研究方向&#xff1a;安全之安全 研究内容&#xff1a;ARM/RISC-V安全架构、TF-A/TEE之安全、GP安全认证、静态代码分析、FUZZ模糊测试、IDA逆向分析、安全与功耗等&#xff0c;欢迎您的关注&#x1f496;&#x1f496; 一、ARM安全架构 1、Trustzone安全研究综述文章推荐 2、T…

allure测试报告

使用pytest结合Allure进行测试报告生成的简单教程 allure测试报告 Allure基于Java开发&#xff0c;因此我们需要提前安装Java 8或以上版本的环境。 ◆安装allure-pytest插件在DOS窗口输入命令“pip3 install allure-pytest”&#xff0c;然后按“Enter”键。 下载安装Allure…

中科亿海微RAM使用

引言 FPGA&#xff08;Field Programmable Gate Array&#xff0c;现场可编程门阵列&#xff09;是一种可编程逻辑设备&#xff0c;能够根据特定应用的需求进行配置和重新编程。在FPGA中&#xff0c;RAM&#xff08;Random Access Memory&#xff0c;随机存取存储器&#xff09…