java_线程池三个常用方式
1.Java_第一季_JAVASE_自增、单例模式、类与实例初始化过程、方法参数传递机制、递归和迭代、成员变量与局部变量2.Java_第一季_SSM_Spring Bean的作用域、Spring事务的传播行为、Spring MVC的执行流程、3.Java_第一季_java高级_Redis持久化、MySql何时建立索引4.java_JUC、volatile5.java_CAS6.java_阻塞队列(FIFO先进先出)7.JUC下countDownLatch、CyclicBarrier、Semaphore以及枚举的常见使用方法8.java_锁9.java_集合不安全10.Spring循环依赖11.AbstractQueuedSynchronizer---AQS12.LockSuport13.java_线程池7大参数_底层运行原理
14.java_线程池三个常用方式
15.Java_Callable<V>的基本使用16.java_锁_synchronized与Lock的区别17.java_强、软、弱、虚四大引用18.java_OOM19.JAVA-interview20.java_NIO21.java_JVM之GC22.java_JVM23.单例模式设计24.netty服务端、客户端简单搭建25.java使用webSocket与前端通讯26.java串口通讯27.用Java读取文件文字并语音播报28.Proguard-混淆29.Spring Security30.MQ31.spring相关面试题32.执行jar包33.Spring34.SpringBoot数据访问35.Java Stream(流)基本使用36.java集合工具类 Collections基本使用37.LocalDateTime、LocalDate、Date、String相互转化38.java8新特性39.java设计模式40.java springboot使用定时器41.MQ根据正常队列、死信队列来实现延迟队列的场景
2、线程池的使用方式
常见三种方式(重要)
Executors.newFixedThreadPool(int);//创建一个线程池,该线程池重用固定数量的从共享无界队列中运行的线程。
Executors.newSingleThreadExecutor();//创建一个使用从无界队列运行的单个工作线程的执行程序。
Executors.newCachedThreadPool();//创建一个根据需要创建新线程的线程池,但在可用时将重新使用以前构造的线程。
示例代码:
import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; //线程池 public class MyThreadPoolDemo { public static void main(String[] args) { //获取当前cpu处理器数量 //System.out.println(Runtime.getRuntime().availableProcessors()); ExecutorService threadPool = Executors.newFixedThreadPool(5);//一池固定数处理线程 try { //模拟10个用户办理业务 for (int i = 1; i <= 10; i++) { threadPool.execute(() ->{ System.out.println(Thread.currentThread().getName()+"\t 办理业务"); }); } }catch (Exception e){ e.printStackTrace(); }finally { threadPool.shutdown(); } } }
更改代码:
ExecutorService threadPool = Executors.newSingleThreadExecutor();//一池一个处理线程
更改代码:
ExecutorService threadPool = Executors.newCachedThreadPool();//一池可扩容数处理线程
更改代码如下:
try { //模拟10个用户办理业务 for (int i = 1; i <= 10; i++) { threadPool.execute(() ->{ System.out.println(Thread.currentThread().getName()+"\t 办理业务"); }); TimeUnit.SECONDS.sleep(1);//每一秒钟只有一个人来办理业务 } }
三种常用方式总结:
第四种方式(了解)
Executors.newScheduledThreadPool(int corePoolSize);//创建一个线程池,可以调度命令在给定的延迟之后运行,或定期执行。
Executors.newScheduledThreadPool(int corePoolSize, ThreadFactory threadFactory);//创建一个线程池,可以调度命令在给定的延迟之后运行,或定期执行。
第五种(java8新出)
Executors.newWorkStealingPool();//
创建使用所有 available processors
作为其目标并行级别的工作窃取线程池。
Executors.newWorkStealingPool(int parallelism);//创建一个维护足够的线程以支持给定的并行级别的线程池,并且可以使用多个队列来减少争用。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?