使用SPRING中的線程池ThreadPoolTaskExecutor實現併發

使用SPRING中的線程池ThreadPoolTaskExecutor實現併發。


一:不需要返回值的情況 
1,初始化線程池

Java代碼  收藏代碼
  1. ThreadPoolTaskExecutor poolTaskExecutor = new ThreadPoolTaskExecutor();  
  2. poolTaskExecutor.setQueueCapacity(10000);  
  3. poolTaskExecutor.setCorePoolSize(5);  
  4. poolTaskExecutor.setMaxPoolSize(10);  
  5. poolTaskExecutor.setKeepAliveSeconds(5000);  
  6. poolTaskExecutor.initialize();  

 

2,在線程池中執行某個線程

Java代碼  收藏代碼
  1. poolTaskExecutor.execute(new Thread(Objct...){...});  

 

二:需要返回值的情況 
1,初始化線程池poolTaskExecutor,同上

 

2,新建一個類,實現Callable接口

Java代碼  收藏代碼
  1. class GetFromDB implements Callable<User> {  
  2.     private UserDao userDao;  
  3.     private Long userId;  
  4.   
  5.     public GetFromDB(UserDao userDao, Long userId) {  
  6.         this.userDao = userDao;  
  7.         this.userId = userId;  
  8.     }  
  9.   
  10.     public User call() throws DaoException {  
  11.         User user = userDao.getUserById(userId);  
  12.         return user;  
  13.     }  
  14. }  

 

3,用之前的GetFromDB類構造一個FutureTask類

Java代碼  收藏代碼
  1. FutureTask<User> dbtask = new FutureTask<User>(GetFromDB);  

 

4,提交併執行

Java代碼  收藏代碼
  1. threadpool.submit(dbtask);  

 

5,得到返回值

Java代碼  收藏代碼
  1. try {  
  2.     User user = dbtask.get();  
  3. catch (Exception e) {  
  4.     if (e instanceof ExecutionException  
  5.             && ((ExecutionException) e).getCause() instanceof DaoException) {  
  6.         throw (DaoException) ((ExecutionException) e).getCause();  
  7.     } else {  
  8.         其他處理方式  
  9.     }  
  10. }  
 

 

注:一旦調用了get()方法,如果線程還未產生返回值,則將阻塞get()方法,直到得到返回值。基於此,如果你想確保線程執行完後才執行下一步操作,即使你不想得到返回值也可以調用一下此方法。當然這與多線程的初衷不符。 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章