• 每个 Java 开发人员都应该知道的关于线程、Runnable和线程池的知识

    云和安全管理服务专家新钛云服 黄平安翻译

    多线程是Java 中最复杂和最强大的部分

    多线程章节是 Java 中最难理解和使用的章节。不幸的是,没有多少资源可以让您获得所有答案。同时,并发知识至关重要。在本文中,我解释了每个 Java 开发人员都必须了解的多线程的核心方面。在这一部分中,我们从 Thread 和 Runnable 主题开始。

    为什么并发知识如此重要?

    如果没有良好的多线程知识,您将无法获得高级 Java 工作

    几乎可以肯定,多线程知识是 Java 高级职位面试的主题。如果没有对多线程的清晰理解,无论是否有实践经验,你很可能会失败。

    每个 Java 开发人员都应该知道的关于线程、Runnable和线程池的知识

    几乎每个生产应用程序都使用多线程范式

    在实际项目的实践中,您将使用应用程序服务器或其替代品。它们都基于线程池等多线程解决方案。任何在其之上的适当实现都需要并发一致性。

    每个 Java 开发人员都应该知道的关于线程、Runnable和线程池的知识

    线程和可运行定义

    多线程基于 Thread 和 Runnable。Thread 是一个启动新的独立活动并执行 Runnable 提供的指令的类。

    每个 Java 开发人员都应该知道的关于线程、Runnable和线程池的知识

    线程是一个附加到操作系统的实体,所以这就是它是一个重类的原因。同时 Runnable 只是一组指令——所以这就是为什么它是轻量级的。

    每个 Java 开发人员都应该知道的关于线程、Runnable和线程池的知识

    如何执行新线程

    线程可以通过使用Run()方法在当前运行的线程内部执行指令。为了在新活动中运行指令,Thread 提供了Start()方法。

    每个 Java 开发人员都应该知道的关于线程、Runnable和线程池的知识

    每个 Java 开发人员都应该知道的关于线程、Runnable和线程池的知识

    如何重用线程

    线程可以在其中执行许多可运行的任务。这是一篇更详细的文章。在这里,您可以看到一个非常简短的示例,其中许多可运行对象(任务)在一个线程中运行:

    每个 Java 开发人员都应该知道的关于线程、Runnable和线程池的知识

    每个 Java 开发人员都应该知道的关于线程、Runnable和线程池的知识

    如何停止线程

    你不能只是stop()或suspend()线程。这些方法已弃用。您必须注意使用isAlive()或的中断设计isInterrupted()

    每个 Java 开发人员都应该知道的关于线程、Runnable和线程池的知识

    每个 Java 开发人员都应该知道的关于线程、Runnable和线程池的知识

    线程守护进程

    线程可以是守护进程。即使最后一部分不会执行,守护线程也会立即中断。所以这样的线程可以附加到资源上。否则,它们可能是资源或/和内存泄漏的原因。

    每个 Java 开发人员都应该知道的关于线程、Runnable和线程池的知识

    每个 Java 开发人员都应该知道的关于线程、Runnable和线程池的知识

    如何使用线程池

    只要 Thread 实例很重,使用 ThreadPool 类重用相同的 Thread 是有意义的。您可以根据线程使用不同的 ThreadPool 实现。

    · 固定线程池

    FixedThreadPool 是一个具有预定义线程数的简单池。期间线程数不会改变。使用它是有意义的:

    每个 Java 开发人员都应该知道的关于线程、Runnable和线程池的知识

    · 缓存线程池

    与Fixed Thread Pool相反,这个可以在添加更多任务时动态增加线程数。每个新创建的线程在使用时都将处于活动状态,否则将在空闲 60 秒后将其删除。

    每个 Java 开发人员都应该知道的关于线程、Runnable和线程池的知识

    如何定义线程池中的线程数

    为了为您的应用程序使用最好的线程池,您需要了解以下内容:

    • 如果您的线程执行大量计算,例如视频渲染、加密等,那么它会吃掉运行该线程的进程。
    • 如果您的线程运行与 CPU 活动(如网络调用、内存调用等)无关,则它不会消耗运行其线程的 CPU。
    每个 Java 开发人员都应该知道的关于线程、Runnable和线程池的知识

    依靠这些知识,您可能会得出以下结论:

    • 拥有高 CPU 消耗任务的任务分配的线程数不会超过 CPU 内核数。
    每个 Java 开发人员都应该知道的关于线程、Runnable和线程池的知识

    • 对于 CPU 消耗较低的任务,您可以拥有比 CPU 内核更多的线程(但比例取决于具体情况)。
    每个 Java 开发人员都应该知道的关于线程、Runnable和线程池的知识

    结论:

    本文仅重点介绍有关线程、可运行和线程池概念的主要内容,但并未完全涵盖。仍有许多方面可能发挥重要作用。我希望你喜欢我使用的信息图表。如果您认为我遗漏了与此主题相关的重要内容,请留下您的反馈。谢谢阅读!

    *原文链接:https://dzone.com/articles/what-every-java-dev-should-know-thread-runnable-thread-pool

    *本文部分图片源于网络,如有侵权请联系删除

    «
    »
以专业成就每一位客户,让企业IT只为效果和安全买单

以专业成就每一位客户,让企业IT只为效果和安全买单