`

Spring线程池配置

 
阅读更多

1、配置文件中配置线程池

<!-- 异步线程池 -->

<bean id="taskExecutor"

class="org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor">

<!-- 核心线程数 -->

<property name="corePoolSize" value="10" />

<!-- 最大线程数 -->

<property name="maxPoolSize" value="100" />

<!-- 队列最大长度 >=mainExecutor.maxSize -->

<property name="queueCapacity" value="1000" />

<!-- 线程池维护线程所允许的空闲时间 -->

<property name="keepAliveSeconds" value="300" />

<!-- 线程池对拒绝任务(无线程可用)的处理策略 -->

<property name="rejectedExecutionHandler">

<bean class="java.util.concurrent.ThreadPoolExecutor$CallerRunsPolicy" />

</property>

</bean>

 

   corePoolSize:线程池至少有2个线程是启动的,即使是空闲的也不会关闭。

   maxPoolSize:最大的线程数目,当corePoolSize繁忙时,会创建线程,启动的总的线程数不能大于maxPoolSize     

   queueCapacity:queueCapacity: 队列大小,当corePoolSize没有空闲线程的时候,允许queueCapacity个线程任务等待,queueCapacity队列满时,才会在corePoolSize的基础上,maxPoolSize之内进行新的线程的创建。

   keepAliveSeconds: 单位毫秒,超过这个时间后会将大于corePoolSize的线程关闭

   rejectedExecutionHandler: 拒绝执行任务的具体操作策略,AbortPolicy表示抛出RejectedExecutionException异常。还有其他的几种选择。CallerRunsPolicy:主线程执行该任务,执行完之后尝试添加下一个任务到线程池中,可以有效降低向线程池内添加任务的速度。

 

2、使用线程池的实现类

import org.springframework.beans.factory.annotation.Autowired;

import org.springframework.core.task.TaskExecutor;

 

public class ThreadPoolTest {

@Autowired

private TaskExecutor taskExecutor;// 线程池

        

        //也可以用如下方式引入线程池

    //@Resource(name = "taskExecutor")
    //private TaskExecutor taskExecutor;

 

// 将创建的线程添加到线程池中

public void test() throws Exception {

for (int i = 0; i < 10; i++) {

this.taskExecutor.execute(new AppContentDataPushThread());

}

}

        //线程类

class AppContentDataPushThread implements Runnable {

 

public AppContentDataPushThread() {

}

 

@Override

public void run() {

System.out.println("执行线程");

                        //业务代码

}

}

}

 

 

 

 

 

 

 

 

 

 

 

 

 

 

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics