多线程查询

本文介绍了使用Java的ExecutorService和ThreadPoolExecutor进行线程并发处理,以提高数据查询性能。通过CountDownLatch协调多个线程,确保每个查询块执行完毕后关闭线程池,避免资源浪费。
摘要由CSDN通过智能技术生成

//每次查多少条
int limit = 200;
//查询数据总条数
long count = baseMapper.getRelayDetailCount(powerDetailDto.getCustomerCategory());
//线程计数器
CountDownLatch latch = new CountDownLatch(10);
//手动创建多线程
ThreadPoolExecutor executorService = new ThreadPoolExecutor(8, 15, 60, TimeUnit.SECONDS, new LinkedBlockingDeque<>(20),
   new ThreadPoolExecutor.CallerRunsPolicy());
//遍历
for (int i = 0; i < (int) count / limit + 1; i++) {
   final int currentIndex = i;
   executorService.submit(() -> {
      long startIdx = currentIndex * limit;
      long endIdx = (currentIndex + 1) * limit;
      if (endIdx > count) {
         endIdx = count;
      }
      //查询数据
      List<MeterDetailVo> relayDetail = baseMapper.getRelayDetail(powerDetailDto.getCustomerCategory(), startIdx, endIdx);
      latch.countDown(); // 通知完成
   });
}

try {
   // 等待所有任务完成
   latch.await();
   // 没有异常发生,开始关闭线程池
   executorService.shutdown();
   // 等待线程池关闭完成,或者达到超时时间
   if (!executorService.awaitTermination(60, TimeUnit.SECONDS)) {
      // 如果超时,强制关闭线程池
      executorService.shutdownNow();
   }
} catch (InterruptedException e) {
   // 发生中断异常,重新设置中断状态
   Thread.currentThread().interrupt();
   // 尝试关闭线程池
   executorService.shutdownNow();
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值