java – newCachedThreadPool如何重用线程?

javadoc说Executors.newCachedThreadPool返回的服务重用了线程.这怎么可能?
一个线程只能通过调用start启动一次.那么他们如何实现呢?这个服务的线程是在一个无限循环中运行,它们的Runnable-s是按需更换的吗?

最佳答案
Runnable可以调用另一个Runnable.

每个线程只运行一个主Runnable,但Runnable从共享的BlockingQueue获取Runnables并调用它们直到它关闭.

简化它.

final BlockingQueue

您可以阅读代码以了解它是如何实现的.

相关文章

ArrayList简介:ArrayList 的底层是数组队列,相当于动态数组。与 Java 中的数组相比,它的容量能动态增...
一、进程与线程 进程:是代码在数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位。 线程...
本文为博客园作者所写: 一寸HUI,个人博客地址:https://www.cnblogs.com/zsql/ 简单的一个类...
#############java面向对象详解#############1、面向对象基本概念2、类与对象3、类和对象的定义格式4、...
一、什么是异常? 异常就是有异于常态,和正常情况不一样,有错误出错。在java中,阻止当前方法或作用域...
Collection接口 Collection接口 Collection接口 Collection是最基本的集合接口,一个Collection代表一组...