线程池——简单介绍与使用

一、什么是线程池

线程池(Thread Pool)是一种并发编程中常用的技术,用于管理和重用线程。它由线程池管理器、工作队列和线程池线程组成。

虽然创建/销毁线程的开销相较于进程已经很小,但是想要进一步减少创建/销毁进程的开销,就需要用到进程池。

实际上,进程池就是在应用程序启动时创建多个线程,并将这些线程存放在线程池中。需要执行任务时,从线程池中获取一个空闲的线程,将任务分配给线程执行。任务执行完以后,将线程返还给线程池,从而实现线程的复用

二、线程池的参数
  1. int corePoolSize:核心线程数

  2. int maximumPoolSize:最大线程数(包括核心线程数)

  3. long keepAliveTime:最长空闲时间

  4. TimeUnit:时间的单位

  5. BlockingQueue<Runnable> workQueue:阻塞队列(任务队列),用来存放线程池中的任务,可以根据需求灵活选择不同的队列

  6. ThreadFactory threadFactory:线程工厂的体现

  7. RejectedExecutionHandler handler:线程池的拒绝策略

三、线程池的工作流程

第一步:有任务需要调用线程时,线程池先检查是否有空闲线程。如果有,则将任务分配给空闲线程,否则继续下一步

第二步:如果线程池中线程的数量还没有到达最大的限制,线程池就会创建一个新的线程,并将任务分配各线程

第三步:如果线程数量已经达到了最大限制,则将任务放入阻塞队列中等待执行

第四步:当线程池中的线程执行完任务后,会从阻塞队列中获取下一个任务

四、使用Executors 创建常见的线程池
java 复制代码
//创建线程池,限制最大线程数量为5
ExecutorService pool = Executors.newFixedThreadPool(5);
//将任务提交给线程池
pool.submit(new Runnable() {
    @Override
    public void run() {
        System.out.println("hello");
   }
});
//关闭线程池
pool.shutdown();
相关推荐
码界奇点1 小时前
Java设计模式精讲从基础到实战的常见模式解析
java·开发语言·设计模式·java-ee·软件工程
今天的砖很烫2 小时前
ThreadLocal 中弱引用(WeakReference)设计:为什么要 “故意” 让 Key 被回收?
jvm·算法
诗9趁年华3 小时前
深入分析线程池
java·jvm·算法
@老蝴4 小时前
Java EE - 常见的死锁和解决方法
java·开发语言·java-ee
无敌最俊朗@1 天前
02-SQLite 为了防止多人同时乱写,把整个数据库文件“当一本账本加锁”
jvm·数据库·oracle
白露与泡影1 天前
Spring Boot项目优化和JVM调优
jvm·spring boot·后端
缪懿1 天前
JavaEE:多线程基础,多线程的创建和用法
java·开发语言·学习·java-ee
Boop_wu1 天前
[Java EE] 多线程 -- 初阶(2)
java·开发语言·jvm
Chan161 天前
【 Java八股文面试 | JVM篇 内存结构、类加载、垃圾回收与性能调优 】
java·jvm·spring boot·后端·spring·idea
我命由我123452 天前
Java 开发 - 粘包处理器 - 基于消息头 + 消息体(魔数验证、长度验证)
java·网络·后端·网络协议·java-ee·intellij-idea·intellij idea