spring线程池 java_使用SPRING中的线程池ThreadPoolTaskExecutor实现JAVA并发

转自:http://blog.csdn.net/ns_code/article/details/17161237 Java中实现多线程有两种方法:继承Thread类、实现Runnable接口,在程序开发中只要是多线程,肯定永远以实现Runnable接口为主,因为实现Runnable接口相比继承Thread类有如下优势: 1、可以避免由

使用SPRING中的线程池ThreadPoolTaskExecutor实现并发。

一:不需要返回值的情况

1,初始化线程池

ThreadPoolTaskExecutor poolTaskExecutor = new ThreadPoolTaskExecutor();

poolTaskExecutor.setQueueCapacity(10000);

poolTaskExecutor.setCorePoolSize(5);

poolTaskExecutor.setMaxPoolSize(10);

poolTaskExecutor.setKeepAliveSeconds(5000);

poolTaskExecutor.initialize();

2,在线程池中执行某个线程

poolTaskExecutor.execute(new Thread(Objct...){...});

二:需要返回值的情况

1,初始化线程池poolTaskExecutor,同上

2,新建一个类,实现Callable接口

class GetFromDB implements Callable {

private UserDao userDao;

private Long userId;

public GetFromDB(UserDao userDao, Long userId) {

this.userDao = userDao;

this.userId = userId;

}

public User call() throws DaoException {

User user = userDao.getUserById(userId);

return user;

}

}

3,用之前的GetFromDB类构造一个FutureTask类

FutureTask dbtask = new FutureTask(GetFromDB);

4,提交并执行

threadpool.submit(dbtask);

5,得到返回值

try {

User user = dbtask.get();

} catch (Exception e) {

if (e instanceof ExecutionException

&& ((ExecutionException) e).getCause() instanceof DaoException) {

throw (DaoException) ((ExecutionException) e).getCause();

} else {

其他处理方式

}

}

注:一旦调用了get()方法,如果线程还未产生返回值,则将阻塞get()方法,直到得到返回值。基于此,如果你想确保线程执行完后才执行下一步操作,即使你不想得到返回值也可以调用一下此方法。当然这与多线程的初衷不符。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值