Java中的线程池可以帮助您管理多个线程,而不必手动管理它们。newCachedThreadPool是Java中的一种线程池,它使用一个可缓存的线程池,该线程池会在需要时自动创建线程,并在当前线程结束后将其回收。
以下是使用newCachedThreadPool线程池的步骤:
- 导入java.util.concurrent.Executors类。
import java.util.concurrent.Executors;
- 创建一个ExecutorService对象,该对象使用newCachedThreadPool线程池:
ExecutorService executor = Executors.newCachedThreadPool();
- 将任务提交到线程池:
executor.execute(new Runnable() {
public void run() {
// 任务代码
}
});
- 在所有任务完成后,关闭线程池:
executor.shutdown();
newCachedThreadPool线程池会自动创建和终止线程,因此您不必手动创建或销毁线程。线程池会根据需要动态调整线程数,在需要大量线程时会创建更多线程,在较少线程时会回收线程。因此,使用newCachedThreadPool线程池可以让您更有效地管理多个线程。
结论 1.newCachedThreadPool最大的核心是int的最大值,如果有业务会在核心数内一直创建线程,导致CPU占用非常的高。 2.SynchronousQueue在此仅用于阻塞,不会进行何的缓存。 3.当创建的线程在业务未完成前,如果已达到最大核心数则不能再创建线程,如果再继续创建则会抛出异常。当可能worker有空的时候可以再次执行业为。可以看出有点像生产者消费模式,如果消费不及时者会不再继续生产,如果继续生产会导致失败。