spring配置文件
<!-- 引用properties文件里的配置 -->
<bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
<property name="locations">
<list>
<value>classpath:config/setting.properties</value>
</list>
</property>
</bean>
<bean id="taskExecutor" class="org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor">
核心线程数<property name="corePoolSize" value="${task.core_pool_size}" />
最大线程数
<property name="maxPoolSize" value="${task.max_pool_size}" />
队列最大长度
<property name="queueCapacity" value="${task.queue_capacity}" />
线程池维护线程所允许的空闲时间,默认为60s
<property name="keepAliveSeconds" value="${task.keep_alive_seconds}" />
</bean>
properties文件:
task.core_pool_size=20
task.max_pool_size=100
task.queue_capacity=1000
task.keep_alive_seconds=60
在需要线程池的地方实现多线程:
实现方法三种:
1.实现runnable接口
2.继承Thread类
3.匿名内部类形式(无需封装类)
参数:
@Resource(name = "taskExecutor")
private TaskExecutor taskExecutor;
方法中:
taskExecutor.execute(new Runnable() {
@Override
public void run() {
try {
//需要进行的操作
} catch (Exception e) {
e.printStackTrace();
}
}
});