线程池——Executor、Executors、ExecutorService、ThreadPoolExecutor、ThreadPoolTaskExecutor之间的区别

在这里插入图片描述
层次关系:

public interface ExecutorService extends Executor {}
public abstract class AbstractExecutorService implements ExecutorService {}
public interface ScheduledExecutorService extends ExecutorService {}

public class ThreadPoolExecutor extends AbstractExecutorService {}
public class ScheduledThreadPoolExecutor extends ThreadPoolExecutor implements ScheduledExecutorService {}
ExecutorService 接口继承了Executor 接口,是Executor 的子接口。
  • 1.Executor接口中定义了execute()方法,用来接收一个Runnable接口的对象,
          而ExecutorService接口中定义的submit()方法可以接收Runnable和Callable接口对象。

  • 2.Executor接口中execute()方法不返回任何结果,而ExecutorService接口中submit()方法可以通过一个 Future 对象返回运算结果。

  • 3.Executor和ExecutorService除了允许客户端提交一个任务,ExecutorService 还提供用来控制线程池的方法。
         比如:调用 shutDown() 方法终止线程池。

Executors 类提供工厂方法用来创建不同类型的线程池

比如:
    Executors.newSingleThreadExecutor() 创建一个只有一个线程的线程池,
    Executors.newFixedThreadPool(int numOfThreads)来创建固定线程数的线程池,
   Executors.newCachedThreadPool()创建一个可缓存线程池,如果线程池长度超过处理需要,可灵活回收空闲线程,若无可回收,则新建线程。
   Executors.newScheduledThreadPool(int corePoolSize) 创建一个线程池,它可安排在给定延迟后运行命令或者定期地执行。

ThreadPoolExecutor

这个类是JDK中的线程池类,继承自Executor,里面有一个execute()方法,用来执行线程,线程池主要提供一个线程队列,队列中保存着所有等待状态的线程。

使用方式有两种,可以通过工具类或者构造方法.

线程池创建方式一:构造方法(传入相应的参数即可).

private static final ThreadPoolExecutor executor = new ThreadPoolExecutor(2, 2, 300, TimeUnit.SECONDS, new LinkedBlockingQueue<Runnable>(1200), new DiscardOldestPolicy());

线程池创建方式二:
通过Executors工具类.
Executors类,提供了一系列工厂方法用于创建线程池,返回的线程池都实现了ExecutorService接口.

1、public static ExecutorService newFiexedThreadPool(int Threads)
创建固定数目线程的线程池。

2、public static ExecutorService newCachedThreadPool():
创建一个可缓存的线程池,调用execute 将重用以前构造的线程(如果线程可用)。如果没有可用的线程,则创建一个新线程并添加到池中。终止并从缓存中移除那些已有 60 秒钟未被使用的线程。

3、public static ExecutorService newSingleThreadExecutor():
创建一个单线程化的Executor。

4、public static ScheduledExecutorService newScheduledThreadPool(int corePoolSize)
创建一个支持定时及周期性的任务执行的线程池,多数情况下可用来替代Timer类。

ThreadPoolTaskExecutor

这个类则是spring包下的,是sring为我们提供的线程池类,可以使用基于xml配置的方式创建.

<bean id="callerRunsPolicy" class="java.util.concurrent.ThreadPoolExecutor.CallerRunsPolicy"/>
 
    <!-- 线程池 -->
    <bean id="taskExecutor"
          class="org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor">
        <!-- 线程池维护线程的最少数量 -->
        <property name="corePoolSize" value="10"/>
        <!-- 线程池维护线程所允许的空闲时间 -->
        <property name="keepAliveSeconds" value="3000"/>
        <!-- 线程池维护线程的最大数量 -->
        <property name="maxPoolSize" value="100"/>
        <!-- 线程池所使用的缓冲队列 -->
        <property name="queueCapacity" value="200000"/>
        <!-- 阻塞机制 -->
        <property name="rejectedExecutionHandler" ref="callerRunsPolicy"/>
    </bean>

或者 注解config
线程池创建方式三

@Bean("yzzxTaskAsyncPool")
    public Executor getAsyncExecutor() {
        ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();
        executor.setCorePoolSize(10);
        executor.setMaxPoolSize(50);
        executor.setThreadNamePrefix("async-pool-");
        // 这一步是关键,异步Task装饰器
        executor.setTaskDecorator(new ContextDecorator());
        executor.initialize();
        return executor;
    }

注:ThreadPoolTaskExecutor中的excute和submit方法的区别?

无返回值的任务使用execute方法提交;

有返回值的任务使用submit(Callable) 方法提交。

使用submit提交任务,提交后只要有从Future取数据的操作,那么主线程在子线程结束后才会结束.

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ExecutorServiceThreadPoolExecutor都是Java中用于管理线程池的接口和类,它们之间有一些区别ExecutorService是一个接口,定义了一组管理线程池的方法,比如提交任务、关闭线程池等。它继承自Executor接口,并扩展了一些新的方法。 ThreadPoolExecutorExecutorService接口的实现类,是Java提供的默认线程池实现。它是一个具体的线程池实现,可以直接使用或者通过工厂方法创建。ThreadPoolExecutor提供了更多的参数和配置选项,可以根据具体需求进行灵活的配置。 区别主要体现在以下几点: 1. 构造方式:ExecutorService可以通过Executors类中的工厂方法来创建,默认使用ThreadPoolExecutor实现。而ThreadPoolExecutor可以直接通过构造方法创建。 2. 灵活性:ThreadPoolExecutor提供了更多的参数和配置选项,可以进行更细粒度的线程池配置,比如核心线程数、最大线程数、线程空闲时间等。而ExecutorService提供的方法较为简单,没有这么多配置选项。 3. 扩展性:由于ExecutorService是一个接口,可以通过继承或实现该接口来扩展自定义的线程池实现。而ThreadPoolExecutor是一个具体的实现类,在可配置的基础上更为灵活,但无法直接扩展。 总结起来,ExecutorService是一个接口,提供了管理线程池的方法;而ThreadPoolExecutorExecutorService的实现类,提供了更多的参数和配置选项,可以更灵活地配置线程池。在大多数情况下,我们可以直接使用ExecutorService来管理线程池,而在需要更高度的可配置性时,可以使用ThreadPoolExecutor
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值