为什么线程创建被认为成本高昂?
虽然 Java 教程声明创建线程会产生大量成本,但其背后的实际原因费用仍不清楚。本文深入研究了 JVM 中线程创建的机制,以揭示导致其成本高昂的因素。
平台相关的开销
线程创建需要以下开销不同平台有所不同。在主机操作系统中建立本机线程、为线程堆栈分配大内存块以及初始化 JVM 和操作系统数据结构都会增加此开销。
资源消耗
一旦创建,本机线程在其整个生命周期中会消耗大量资源。其中包括分配的线程堆栈、可从堆栈访问的对象、JVM 线程描述符和操作系统本机线程描述符。
基准测试证据
基准测试练习显示线程创建在 2002 年运行 Java 1.4.1 的双处理器 Xeon 系统上,发生率约为每秒 4000 个。虽然性能有所提高,但线程创建仍然相对昂贵。
虚拟线程和 Project Loom
出于性能原因,Java 平台传统上采用本机线程。然而,OpenJDK Loom 项目引入了虚拟线程作为潜在的解决方案。这些线程是结合了本机线程和绿色线程的混合体,旨在减少与本机线程创建相关的开销,同时保持并发性。
OpenJDK 中的堆栈分配
OpenJDK 6 Linux 上使用 mmap 通过 pthread_create 调用为本机线程分配堆栈内存。该内存自动初始化为零,与 JVM 规范中有关新 Java 线程堆栈归零的假设保持一致。
总而言之,由于建立新线程涉及大量开销,因此线程创建被认为是昂贵的本机线程,分配大内存块,并在其生命周期内消耗各种资源。此外,特定于平台的因素会影响线程创建的精确成本。
以上是为什么在 Java 中创建线程被认为是昂贵的?的详细内容。更多信息请关注PHP中文网其他相关文章!