线程池ExecutorService 及CountDownLatch 并发执行查询接口

1 篇文章 0 订阅
1 篇文章 0 订阅
public static Map<String ,List<Map<String, Object>>> getMaps(List<String> sqlKeys) throws InterruptedException, ExecutionException{
	    if(CollectionUtils.isEmpty(sqlKeys)) {
		return null;
	    }
	    Map<String ,List<Map<String, Object>>> map = new HashMap<String ,List<Map<String, Object>>>();
	    ExecutorService executorService = Executors.newFixedThreadPool(2);
	    final CountDownLatch countDownLatch = new CountDownLatch(2);
	    Future<List<Map<String, Object>>> outputDatas = executorService.submit(new Callable<List<Map<String, Object>>>() {
	    @Override
	    public List<Map<String, Object>> call() throws Exception {
	    		try {
	    			return new HanaJdbc().querySQLForList(PropertyPlaceholderUtil.getProperty("COMPANY.CODE"), null, false);
	    		}finally {
	    			countDownLatch.countDown();
				}
	    	}
		});
	    
	    Future<List<Map<String, Object>>> outputDatas2 = executorService.submit(new Callable<List<Map<String, Object>>>() {
	    	@Override
	    	public List<Map<String, Object>> call() throws Exception {
	    		try {
	    			return new HanaJdbc().querySQLForList(PropertyPlaceholderUtil.getProperty("UNIT.CODE"), null, false);
	    		}finally {
	    			countDownLatch.countDown();
				}
	    	}
		});
	    
	    countDownLatch.await();
	    map.put("COMPANY.CODE", outputDatas.get());
	    map.put("UNIT.CODE", outputDatas2.get());
	    return map;
	}

1.如果outputDatas和outputDatas2的执行时间分别是2秒的/3秒,那么这个方法的最终执行时间是3秒多一点点,

2.如果两者之间没有任何数据上的前置作用,那么可以这样写,性能可以大幅提升。

 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

lesliehu2158

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值