使用CountDownLatch做并行任务时死锁问题解决

一、业务背景

    因为业务需求背景,某些功能页面会请求较多的网络接口,毕竟后端更多的是考虑业务的解耦,会造成客户端优化较多接口请求导致的等待耗时(转圈)问题,后端推动接口的合并困难,但是前端也是可以做一些优化的。
    经过一番调研,最后选择使用较为常用的CountDownLatch配合线程池将无依赖的接口由串行改成并行,起初是使用同一个线程池,结果在拆分任务较多时,并发量大时出现了线程死锁问题,最后通过Android Studio自带的dump线程的功能,分析发现是在线程池的任务队列中死锁了。

二、解决方案

    将需要并行执行的网络请求任务放到不同的线程池就不会死锁了。

你可能感兴趣的:(开发经验总结,java,性能优化)