什么是 Java 中的 Executor Framework 以及如何使用它?
Java 始终对并发和多线程编程有很强的支持。 但一开始,直到 Java 5,支持的形式是在应用层调用本层构造本身。 这是一个缺点,因为我们无法更有效地处理原始调用。 所以,这篇关于Java中 Executor Framework 的文章提出了这个问题的解决方案。
什么是 Executor Framework ? 为什么要使用它?
Executor Framework 包含一组用于有效管理多个线程的组件。 它与 JDK 5 一起发布,用于运行 Runnable
对象,而无需每次都创建新线程,并且主要重用已创建的线程。
这个 Executor API 将任务的执行与要在 Executor 的帮助下执行的实际任务分离。 这以 Executor 接口及其子接口 ExecutorService 和类 ThreadPoolExecutor 为中心。
通过使用这个执行器,只需要实现可运行对象并将它们发送到执行器执行。
让我们看一个例子。
public class Test implements Runnable {
private String message;
public Test(String message) {
this.message = message;
}
@Override
public String run() throws Exception {
return "Hello " + message + "!";
}
}
在这个例子中,Test 类实现了 Runnable 并被参数化为字符串类型。 它也被声明为抛出异常。 另外,请注意,这种向 executor 抛出异常以及 executor 将此异常返回给 runner 的能力非常重要,因为它有助于 runner 了解任务执行的状态。
让我们进入本文的下一部分,看看 Java 中不同类型的 Executor 框架。
执行器的类型
主要有 4 种类型的 Executors 可用。 它们是:
- SingleThreadExecutor
- FixedThreadPool
- CachedThreadPool
- ScheduledExecutor
SingleThreadExecutor
这个执行器只有一个线程,用于按顺序执行任务。 如果任何线程在执行任务时因异常而死亡,则创建一个新线程来替换旧线程,并在新线程中执行后续任务。
FixedPoolExecutor
这是一个固定数量的线程池。 提交给执行器的任务由“n”个线程执行,假设如果还有更多任务要完成,它们将存储在 LinkedBlockingQueue
中。
CachedThreadExecutor
这主要用于在线上有大量短期并行任务等待执行的情况。 与固定线程池相比,这里这个执行器池的线程数是没有限制的。 如果所有线程都忙于执行分配的任务,并且当有新任务时,它将创建一个新线程并将其添加到执行程序。 如果一个线程保持空闲接近 60 秒,它们将被终止并从缓存中删除。
ScheduledExecutor
当有需要定期运行的任务或者我们希望延迟某个任务时使用此执行程序。 可以使用 scheduleAtFixedRate 或 scheduleWithFixedDelay 两种方法之一在 ScheduledExecutor 中安排任务。
最佳实践
- 始终针对 PMD 和 FindBugs 等静态分析工具运行 Java 代码。
- 请注意交叉检查并计划更好的代码来查看顶级列表,以便在执行期间检测代码中可能存在的死锁或活锁。
- 在多线程程序中,养成及时捕捉错误的习惯,而不仅仅是异常。
相关文章
如何在 Java 中延迟几秒钟的时间
发布时间:2023/12/17 浏览次数:217 分类:Java
-
本篇文章主要介绍如何在 Java 中制造程序延迟。本教程介绍了如何在 Java 中制造程序延时,并列举了一些示例代码来了解它。
如何在 Java 中把 Hashmap 转换为 JSON 对象
发布时间:2023/12/17 浏览次数:187 分类:Java
-
它描述了允许我们将哈希图转换为简单的 JSON 对象的方法。本文介绍了在 Java 中把 Hashmap 转换为 JSON 对象的方法。我们将看到关于创建一个 hashmap,然后将其转换为 JSON 对象的详细例子。
如何在 Java 中按值排序 Map
发布时间:2023/12/17 浏览次数:171 分类:Java
-
本文介绍了如何在 Java 中按值对 Map 进行排序。本教程介绍了如何在 Java 中按值对 Map
进行排序,并列出了一些示例代码来理解它。
如何在 Java 中打印 HashMap
发布时间:2023/12/17 浏览次数:192 分类:Java
-
本帖介绍了如何在 Java 中打印 HashMap。本教程介绍了如何在 Java 中打印 HashMap 元素,还列举了一些示例代码来理解这个主题。
在 Java 中更新 Hashmap 的值
发布时间:2023/12/17 浏览次数:146 分类:Java
-
本文介绍了如何在 Java 中更新 HashMap 中的一个值。本文介绍了如何在 Java 中使用 HashMap 类中包含的两个方法-put() 和 replace() 更新 HashMap 中的值。
Java 中的 hashmap 和 map 之间的区别
发布时间:2023/12/17 浏览次数:79 分类:Java
-
本文介绍了 Java 中的 hashmap 和 map 接口之间的区别。本教程介绍了 Java 中 Map 和 HashMap 之间的主要区别。在 Java 中,Map 是用于以键值对存储数据的接口,
在 Java 中获取用户主目录
发布时间:2023/12/17 浏览次数:218 分类:Java
-
这篇文章向你展示了如何在 Java 中获取用户主目录。本教程介绍了如何在 Java 中获取用户主目录,并列出了一些示例代码以指导你完成该主题。
Java 中 size 和 length 的区别
发布时间:2023/12/17 浏览次数:179 分类:Java
-
这篇文章教你如何知道 Java 中大小和长度之间的区别。本教程介绍了 Java 中大小和长度之间的区别。我们还列出了一些示例代码以帮助你理解该主题。
Java 中的互斥锁
发布时间:2023/12/17 浏览次数:111 分类:Java
-
了解有关 Java 中互斥锁的一切,在计算机科学领域,互斥或互斥被称为并发控制的属性。每台计算机都使用称为线程的最小程序指令序列。有一次,计算机在一个线程上工作。为了更好地理解,