java线程池关闭

工作日志:

ExecutorService esPool = Executors.newFixedThreadPool(5);
for (Entry entry : treeMap.entrySet())
{
    esPool.submit(() ->
    {
        refreshOldData(entry.getKey(), entry.getValue());
    });
}

项目中遇到这样的代码,很明显此处是没有没有关闭线程的,

于是新增关闭代码,

esPool.shutdown();
根据文中所说的如果操作是异步的,即不需要等待所有线程执行完毕才返回结果或者方法是无返回值的,那么可以不需要下面的线程同步等待应该也可以,直接调用shutdown()然后让所有任务执行完毕后销毁线程即可

//执行此函数后线程池不再接收新任务,并等待所有任务执行完毕后销毁线程。此函数并不会等待线程销毁完毕,而是立即返回的
executor.shutdown();

//如想要同步等待线程池完成关闭,可使用下面的函数判断是否都执行完毕了,该函数等待timeout后,返回是否所有任务都执行完毕了
pool.awaitTermination(timeout,TimeUnit)

//尝试结束所有活动线程,并返回等待队列里的任务
executor.shutdownNow();

你可能感兴趣的:(工作问题)