线程池的简单介绍及使用

本文详细介绍了Java线程池的核心概念,包括核心线程数、最大线程数、保持存活时间等参数,列举了不同的拒绝策略,以及线程池的任务处理流程。同时,展示了如何使用Executors创建常见线程池类型。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

线程池的参数介绍

在这里插入图片描述

  • corePoolSize: (核心线程数)这是线程池中始终存在的线程数,即使这些线程处于空闲状态。
  • maximumPoolSize:(最大线程数) 是线程池允许的最大线程数。
  • keepAliveTime:(保持存活时间)这是非核心线程(超过corePoolSize的线程)在变为空闲状态后可以在队列中等待新任务的最长时间。超过这个时间,如果队列中没有新任务,线程会被终止。
  • unit:时间单位
  • workQueue:这是一个阻塞队列,用于存放等待执行的任务。
  • threadFactory:这是一个用于创建新线程的工厂。
  • handler:这是拒绝策略,用于处理线程池无法处理新任务的情况。

拒绝策略

  • AbortPolicy:超过负荷,直接抛出异常
  • CallerRunsPolicy: 由添加任务的线程负责执行
  • DiscardOldestPolicy:丢弃队列中最⽼的任务
  • DiscardPolicy():丢弃新来的任务

线程池的任务处理流程

如果正在运行的线程数小于corePoolSize,则线程池会创建一个新的工作线程来执行任务。
如果正在运行的线程数大于或等于corePoolSize,任务会被存入工作队列中等待。
如果队列满了,且正在运行的线程数小于maximumPoolSize,线程池会创建一个非核心线程来执行任务。
如果队列满了,且正在运行的线程数大于或等于maximumPoolSize,线程池会采用拒绝策略来处理该任务。

使用Executors创建常见的线程池

  1. newFixedThreadPool:创建一个固定大小的线程池。
  2. newSingleThreadExecutor:创建一个只有一个线程的线程池。因为只有一个线程,所以任务会按照提交顺序依次执行。
  3. newCachedThreadPool:创建一个可缓存的线程池。线程池的大小会根据需要自动调整,空闲线程会在一定时间后被回收。
  4. newScheduledThreadPool:创建一个定时任务的线程池。可以按指定的时间间隔执行任务。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值