今天小编就为大家分享一篇关于springmvc配置线程池Executor做多线程并发操作的代码实例,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
加载xml文件
在applicationcontext.xml文件里面添加xmlns:task="http://www.springframework.org/schema/task" xmlns文件并且xsi:schemalocation中添加http://www.springframework.org/schema/task
http://www.springframework.org/schema/task/spring-task.xsd 在spring中配置executor
在applicationcontext.xml文件里面添加<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>
<!-- 注解式 -->
<task:annotation-driven /> 在dbconfig.properties添加maxopenpreparedstatements=20
removeabandoned=true
removeabandonedtimeout=1800
logabandoned=true 这是分别对线程池做配置
添加依赖注入
在所需要的service或者controller类里面添加@resource(name = "taskexecutor")
private taskexecutor taskexecutor; 使用线程池进行并发操作
代码如下taskexecutor.execute(new runnable() {
@override
public void run() {
// todo auto-generated method stub
try {
//要进行的并发操作
} catch (exception e) {
// todo auto-generated catch block
e.printstacktrace();
}
}
}); 提示
注意在线程中操作变量时候变量的作用域范围。需要在这个controller或者sevice中声明变量如下@controller
public class indexcontroller {
int studentscount = 0;
@requestmapping(value = "/index.html")
public modelandview goindex() {
logbefore(logger, "列表center");
modelandview mv = this.getmodelandview();
taskexecutor.execute(new runnable() {
@override
public void run() {
// todo auto-generated method stub
// 得到所有学生人数
try {
studentscount = coursesservice.getstudentcount(pd);
} catch (exception e) {
// todo auto-generated catch block
e.printstacktrace();
}
}
});
mv.addobject("studentscount", studentscount);
mv.setviewname("common/index");
return mv;
} 总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对CodeAE代码之家的支持。如果你想了解更多相关内容请查看下面相关链接
原文链接:https://blog.csdn.net/u014320421/article/details/79295944
|