工作日志:
ExecutorService esPool = Executors.newFixedThreadPool(5);
for (Entry<Integer, Integer> entry : treeMap.entrySet())
{
esPool.submit(() ->
{
refreshOldData(entry.getKey(), entry.getValue());
});
}
项目中遇到这样的代码,很明显此处是没有没有关闭线程的,
于是新增关闭代码,
esPool.shutdown();
根据文中所说的如果操作是异步的,即不需要等待所有线程执行完毕才返回结果或者方法是无返回值的,那么可以不需要下面的线程同步等待应该也可以,直接调用shutdown()然后让所有任务执行完毕后销毁线程即可
//执行此函数后线程池不再接收新任务,并等待所有任务执行完毕后销毁线程。此函数并不会等待线程销毁完毕,而是立即返回的
executor.shutdown();
//如想要同步等待线程池完成关闭,可使用下面的函数判断是否都执行完毕了,该函数等待timeout后,返回是否所有任务都执行完毕了
pool.awaitTermination(timeout,TimeUnit)
//尝试结束所有活动线程,并返回等待队列里的任务
executor.shutdownNow();