Async整合线程池

本文探讨了在SpringBoot中如何通过@Async进行异步任务处理,避免频繁创建销毁线程导致资源浪费。作者介绍了如何配置自定义线程池,如设置核心线程数、最大线程数等,并演示了如何利用ThreadPoolAyncExecutor进行任务执行,以提高性能和资源利用率。

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

为什么在使用Async 要使用多线程

在spring boot 中使用 @Async 是为了使用多线程,但是在使用过程中你会发现在使用中每一个使用@Async 注解的时候都会产生一个独立线程,这样线程的创建、销毁 就非常销毁cpu。
于是就考虑使用线程池方式实现。

@Async 线程使用如下

  1. 定义线程池
在这里插入代码片
```@Configuration
@EnableAsync
public class AsyncPoolConfig {


    @Bean(name = "ThreadPoolAyncExecutor")
    public ThreadPoolTaskExecutor getScorePoolTaskExecutor() {

        ThreadPoolTaskExecutor taskExecutor = new ThreadPoolTaskExecutor();
        //设置核心线程数
        taskExecutor.setCorePoolSize(10);
        // 线程池维护线程的最大数量,只有在缓冲队列满了以后才会申请超过核心线程数的线程
        taskExecutor.setMaxPoolSize(100);
        //缓存队列
        taskExecutor.setQueueCapacity(50);
        //允许的空闲时间,当超过了核心线程数之外的线程在空闲时间到达之后会被销毁
        taskExecutor.setKeepAliveSeconds(200);
        //异步方法内部线程名称
        taskExecutor.setThreadNamePrefix("score-");
        /**
         * CallerRunsPolicy: 重试添加当前的任务,自动重复 execute()方法,直到成功
         * AbortPolicy:丢弃任务并抛弃RejectedExecutionException
         * DiscardOldestPolicy:丢弃队列里当前的 任务,然后重新尝试执行任务(重复此过程)
         * DiscardPolicy():丢弃任务,不抛出异常
         */
        taskExecutor.setRejectedExecutionHandler(new ThreadPoolExecutor.CallerRunsPolicy());
        taskExecutor.initialize();
        return taskExecutor;
    }
}

 
 2. 使用线程池

```java
    @Async("ThreadPoolAyncExecutor")
    public IotResp pushDeviceCmd(PushOtaInfo pushOtaInfo) {
           int i=0;
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

houxian1103

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值