Spring线程池ThreadPoolTaskExecutor 的配置与使用

本文介绍了如何在Spring中配置和使用ThreadPoolTaskExecutor线程池。内容包括线程池的配置,通过注入线程池相关配置,创建实现Runnable接口的自定义线程类,并在代码中优化线程管理,以防止线程数超过限制引发错误。

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

有关Java线程池,可参见csdn线程池

线程池的配置
<!-- 异步线程池 -->
    <bean id="taskExecutor" class="org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor">
        <!-- 核心线程数  -->
        <property name="corePoolSize" value="10"/>
        <!-- 最大线程数 -->
        <property name="maxPoolSize" value="200"/>
        <!-- 队列最大长度 >=mainExecutor.maxSize -->
        <property name="queueCapacity" value="10"/>
        <!-- 线程池维护线程所允许的空闲时间 -->
        <property name="keepAliveSeconds" value="20"/>
        <!-- 线程池对拒绝任务(无线程可用)的处理策略 -->
        <property name="rejectedExecutionHandler">
            <bean class="java.util.concurrent.ThreadPoolExecutor$CallerRunsPolicy"/>
        </property>
    </bean>
线程池的使用
注入线程池的相关配置
@Resource(name="taskExecutor")
ThreadPoolTaskExecutor taskExecutor;
// 或者可以直接@Autowried
@AutoWired
ThreadPoolTaskExecutor taskExecutor;

注意,再自动注入并创建ThreadPoolTaskExecutor的一个对象时,会执行ThreadPoolTaskExecutor.initialize()方法进行初始化

创建一个实现Runnable接口的自定义线程类
package cn.test.utils;
import org.apache.commons.collections.CollectionUtils;
import java.util.List;
public class RuleThread implements Runnable {
   	// 自定义类的属性及getset方法,用来传输数据
    private String name;
    private List<String> idList;
    public List<String> getIdList() {
        return idList;
    }

    public void setIdList(List<String> idList) {
        this.idList = idList;
    }

    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    // run方法
    @Override
    public void run() {
        excute();
    }
    private void excute() {
        // 编写要执行的业务方法
    }
}

创建自定义线程类对象并调用spring线程池去管理线程
// 初始化线程池
taskExecutor.initialize();
// 创建自定义对象并赋值属性
RuleThread ruleThread = new RuleThread();
ruleThread.setName("当前线程名");
ruleThread.setIdList(new ArrayList());
// 执行线程
taskExecutor.execute(ruleThread);
// 销毁线程池
taskExecutor.destroy();
为防止线程数超过限制报错,优化上面代码如下
// 初始化线程池
taskExecutor.initialize();
for(int i=1;i<10;i++){
    while(true){
        // 创建自定义对象并赋值属性
        RuleThread ruleThread = new RuleThread();
        ruleThread.setName("当前线程名");
        ruleThread.setIdList(new ArrayList());
        // 执行线程
        taskExecutor.execute(ruleThread);
        break;
    }
}
// 销毁线程池
taskExecutor.destroy();
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值