多线程查询

场景:

一个方法内有较多的同步查询操作: 

  Object o1 = dao.selectO1();

  Object o2 = dao.selectO2();

  Object o3 = dao.selectO3();

  ......

 

解决方案:

  开启多线程查询。

 

Demo:

查询:
Future<List<BYDSpecialDetailVo>> mateInfoFuture = JobUtil.submitJob(()->specialDao.getMateData(ids));
Future<List<BYDSpecialDetailVo>> childrenEduFuture= JobUtil.submitJob(()->specialDao.getChildrenEducationData(ids));
Future<List<BYDSpecialDetailVo>> continueEduFuture = JobUtil.submitJob(()->specialDao.getContinuingEducationData(ids));
Future<List<BYDSpecialDetailVo>> hoseLoanFuture = JobUtil.submitJob(()->specialDao.getHousingLoanData(ids));
Future<List<BYDSpecialDetailVo>> hoseRentFuture= JobUtil.submitJob(()->specialDao.getHousingRentData(ids));
Future<List<BYDSpecialDetailVo>> supportElderlyFuture = JobUtil.submitJob(()->specialDao.getSupportingElderlyData(ids));
Future<List<BYDSpecialDetailVo>> infantSupportFuture = JobUtil.submitJob(()->specialDao.getInfantSupportData(ids));

获取结果:
Map<String,BYDSpecialDetailVo> mateInfoMap = JobUtil.getResultToMap(mateInfoFuture);
Map<String,BYDSpecialDetailVo> childrenEduMap = JobUtil.getResultToMap(childrenEduFuture);
Map<String,BYDSpecialDetailVo> continueEduMap = JobUtil.getResultToMap(continueEduFuture);
Map<String,BYDSpecialDetailVo> hoseLoanMap = JobUtil.getResultToMap(hoseLoanFuture);
Map<String,BYDSpecialDetailVo> hoseRentMap = JobUtil.getResultToMap(hoseRentFuture);
Map<String,BYDSpecialDetailVo> supportElderlyMap = JobUtil.getResultToMap(supportElderlyFuture);
Map<String,BYDSpecialDetailVo> infantSupportMap = JobUtil.getResultToMap(infantSupportFuture);

工具类:
public class JobUtil {

private final static ExecutorService EXECUTOR_SERVICE = Executors.newCachedThreadPool();

private final static Map<String,BYDSpecialDetailVo> EMPTY_MAP = new HashMap<>(1);

public static <T> Future<T> submitJob(Callable<T> callable){
return EXECUTOR_SERVICE.submit(callable);
}

public static <T> T getResult(Future<T> future) throws ExecutionException, InterruptedException {
return future.get();
}

public static Map<String, BYDSpecialDetailVo> getResultToMap(Future<List<BYDSpecialDetailVo>> future) throws ExecutionException, InterruptedException {
List<BYDSpecialDetailVo> specialList = getResult(future);
if (CollUtil.isEmpty(specialList)) return EMPTY_MAP;
return specialList.parallelStream().collect(Collectors.toConcurrentMap(BYDSpecialDetailVo::getId, Function.identity(),(old, newValue)->newValue));
}

}



 

posted @   有所_期待  阅读(167)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
点击右上角即可分享
微信分享提示