java线程池中类的继承探究

答案是Java线程池基于Executor框架,通过Executor、ExecutorService接口定义任务执行与生命周期管理,AbstractExecutorService提供默认实现,ThreadPoolExecutor实现核心调度逻辑,ScheduledThreadPoolExecutor支持定时任务,Executors为创建常用线程池的工具类,整体体现分层抽象与模板方法设计模式。

Java线程池的实现主要依赖于Executor框架,其核心类和接口之间存在清晰的继承与实现关系。理解这些类之间的结构有助于更好地掌握线程池的工作机制和扩展方式。

Executor 与 ExecutorService 接口

Executor 是最顶层的接口,只定义了一个方法:execute(Runnable command),用于执行任务。它不关心任务的执行细节,也不提供生命周期管理。

ExecutorService 继承自 Executor,扩展了线程池的生命周期管理和任务提交方式。它提供了如下关键能力:

  • 可以提交返回结果的任务(submit(Callable)
  • 支持关闭线程池(shutdown()shutdownNow()
  • 可以等待任务完成(awaitTermination()

AbstractExecutorService 抽象类

AbstractExecutorService 实现了 ExecutorService 接口,提供了默认实现,比如:

  • submit(Runnable task) 将 Runnable 包装为 FutureTask
  • invokeAll() 批量执行任务并返回结果集合

这个类不实现 execute() 方法,将其留给具体子类实现,体现模板方法模式。

ThreadPoolExecutor 核心实现类

ThreadPoolExecutor 继承自 AbstractExecutorService,是 Java 线程池的核心实现。它管理线程池的状态、工作队列、线程创建与回收等逻辑。

关键构造参数包括:

  • corePoolSize:核心线程数
  • maximumPoolSize:最大线程数
  • workQueue:任务队列
  • threadFactory:线程创建工厂
  • rejectedExecutionHandler:拒绝策略

它实现了 execute() 方法,根据当前线程数量和队列状态决定是创建新线程、入队还是拒绝任务。

ScheduledThreadPoolExecutor 定时任务支持

ScheduledThreadPoolExecutor 继承自 ThreadPoolExecutor,同时实现了 ScheduledExecutorService 接口,支持定时和周期性任务执行。

它重写了任务调度逻辑,使用延迟队列(DelayedWorkQueue)来管理定时任务,确保任务在指定时间触发。

Executors 工具类的角色

Executors 是一个工具类,提供静态工厂方法创建常见类型的线程池,例如:

  • newFixedThreadPool:固定大小线程池
  • newCachedThreadPool:弹性线程池
  • newScheduledThreadPool:支持调度的线程池

这些方法底层都基于 ThreadPoolExecutorScheduledThreadPoolExecutor 构造实例。

基本上就这些。线程池的继承体系体现了面向对象设计中的分层抽象思想:从行为定义到通用实现,再到具体策略。掌握这个结构,有助于在实际开发中灵活定制和优化线程池。