Java 线程池的实现原理
线程的几种状态
public enum State {
NEW,
RUNNABLE,
BLOCKED,
WAITING,
TIMED_WAITING,
TERMINATED;
}
- NEW,新建状态。尚未启动的线程的状态。
- RUNNABLE,可运行状态。处于
RUNNABLE
状态的线程正在 JVM 中执行,但它可能正在等待来自操作系统(如处理器)的其他资源。 - BLOCKED,阻塞状态。处于
BLOCKED
状态的线程正在等待监视器锁以便进入同步代码块或同步方法,或者在调用Object.wait()方法后准备重入同步代码块或同步方法。 - WAITING,等待状态。处于
WAITING
状态的线程正在等待另一个线程执行特定的动作,例如需要另一个线程调用Object.notify()
或者Object.notifyAll()
进行唤醒。当调用以下无参方法时,线程会进入WAITING
状态: Object.wait()
Thread.join()
LockSupport.park()
- TIMED_WAITING,具有指定等待时间的线程状态。当调用以下具有指定正等待时间的方法时,线程会进入
TIMED_WAITING
状态: Thread.sleep(millis)
Object.wait(timeout)
Thread.join(millis)
LockSupport.parkNanos(blocker, nanos)
LockSupport.parkUntil(blocker, deadline)
- TERMINATED,终止状态。当线程执行完成后,处于
TERMINATED
状态。
线程池的实现 ThreadPoolExecutor
public ThreadPoolExecutor(int corePoolSize,
int maximumPoolSize,
long keepAliveTime,
TimeUnit unit,
BlockingQueue<Runnable> workQueue,
ThreadFactory threadFactory,
RejectedExecutionHandler handler) {
if (corePoolSize < 0 ||
maximumPoolSize <= 0 ||
maximumPoolSize < corePoolSize ||
keepAliveTime < 0)
throw new IllegalArgumentException();
if (workQueue == null || threadFactory == null || handler == null)
throw new NullPointerException();
this.corePoolSize = corePoolSize;
this.maximumPoolSize = maximumPoolSize;
this.workQueue = workQueue;
this.keepAliveTime = unit.toNanos(keepAliveTime);
this.threadFactory = threadFactory;
this.handler = handler;
}
- corePoolSize,核心线程数,表示要保留在线程池中的线程数,即使它们处于空闲状态,如果设置了
allowCoreThreadTimeOut
参数,则该参数的最小值可以为零。 - maximumPoolSize,最大线程数,表示线程池中允许同时存在的最大线程数量。
- keepAliveTime,存活时间,当线程池中的线程数量大于
corePoolSize
时,该参数表示多余的空闲线程在终止之前等待新任务的最长时间。也就是说,如果多余的空闲线程在等待时间超过keepAliveTime
之后仍没有收到任务,则自动销毁。 - unit,时间单位,表示
keepAliveTime
参数的时间单位。 - workQueue,工作队列,在任务被执行前,该队列用于保存任务。该队列只能持有被execute方法提交的Runnable类型的任务。
- threadFactory,线程工厂,执行器创建新线程时使用的工厂。
- handler,拒绝策略,当达到线程数量边界和队列容量而阻止执行时使用的处理策略。
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 微软正式发布.NET 10 Preview 1:开启下一代开发框架新篇章
· 没有源码,如何修改代码逻辑?
· PowerShell开发游戏 · 打蜜蜂
· 在鹅厂做java开发是什么体验
· WPF到Web的无缝过渡:英雄联盟客户端的OpenSilver迁移实战