最近的项目出现了一个bug,长连接中使用了异步线程池,具体是有一个循环,每一次循环都用了异步线程,然后呢,在长连接中处理这个循环的同时,还会有前端向后端发送消息,那么后端也要接收相应的消息进行处理,每次循环的异步线程如下
java
Future<Boolean> submit = taskExecutor.submit(new Callable<Boolean>() {
@Override
public Boolean call(){}
});
然后呢还搞了一个
java
private final Map<String, Future<Boolean>> Futures = new ConcurrentHashMap<>();
Futures.put(id, submit);
以id为key保存每一次循环中的异步线程返回值,然后呢,最灵魂的代码来喽,这句代码真是给添了不少麻烦,那就是等待这次异步任务完成,实际上大错特错
java
Future<Boolean> future = Futures.get(id);
Boolean b = future.get();
这句代码乍一看倒是没什么问题,但是呢,在运行的时候,前端向后端发送特定的消息,后端没有响应,哇靠,这是为啥嘞?
没错,就是Boolean b = future.get();把主线程给阻塞了,导致不能处理其他问题,其实这只是一个小问题哈,但是有时候往往是小问题在写代码的时候,加着加着就忘记了,结果排查的时候好半天才看到。
最后的解决办法是啥呢,最后搞了一个异步线程处理这个循环,大致的代码示意如下:
java
CompletableFuture.runAsync(()->
{
for (dto:list) {
Future<Boolean> submit = taskExecutor.submit(new Callable<Boolean>() {
@Override
public Boolean call() {
}
});
}
})