没有队列的ThreadPoolExecutor

我想创建一个固定大小的线程池,不允许任何任务进入其队列。 换句话说,如果当前正在使用线程池,则应该完全拒绝传入的任务。 基于文档 ,在我看来,实现此目的的一种方法是创建一个拒绝接受任务的虚拟Queue对象。 在Java中实现这一目标的惯用方法是什么?

您可以在ThreadPoolExector中使用SynchronousQueue ,这是一个不包含任何对象的队列。 缓存的线程池使用它,因为它根据需要创建新线程。

如果它不能排队但我建议使用RejectedExecutionHandler在当前线程中运行任务。 这样它将始终“立即”运行。

顺便说一句:明确你为什么要这样做会很有用。

你能详细说明你为什么要做这样的事吗? TP + Q的根本目的是为工作提供一个自动“保持机制”,并将工人与工作创建过程分离。 如果你的意图是只有工人可接受的工作包,那么你真的不需要TPE。