Why is Thread Creation Deemed Costly?
While the Java tutorials state that creating a Thread incurs a significant cost, the actual reason behind this expense has remained unclear. This article delves into the mechanics of Thread creation in the JVM to uncover the factors that contribute to its costly nature.
Platform-Dependent Overhead
Thread creation entails overhead that varies across platforms. Establishing a native thread within the host OS, allocating a large memory block for the thread's stack, and initializing JVM and OS data structures all add to this overhead.
Resource Consumption
Once created, a native thread consumes considerable resources throughout its lifetime. These include the allocated thread stack, objects accessible from the stack, JVM thread descriptors, and OS native thread descriptors.
Benchmark Evidence
A benchmarking exercise revealed that thread creation occurred at a rate of approximately 4000 per second on a dual-processor Xeon system running Java 1.4.1 in 2002. While modern platforms offer improved performance, thread creation remains relatively expensive.
Virtual Threads and Project Loom
Java platforms have traditionally employed native threads for performance reasons. However, the OpenJDK Loom project introduces virtual threads as a potential solution. These threads are hybrids that combine native threads and green threads, aiming to reduce the overhead associated with native thread creation while maintaining concurrency.
Stack Allocation in OpenJDK
OpenJDK 6 on Linux employs mmap to allocate stack memory for a native thread through the pthread_create call. This memory is automatically initialized to zero, aligning with the assumptions made in the JVM specification regarding the zeroing of new Java thread stacks.
In summary, thread creation is considered expensive due to the substantial overhead involved in establishing a new native thread, allocating a large memory block, and consuming various resources across its lifetime. Additionally, platform-specific factors influence the precise cost of thread creation.
The above is the detailed content of Why is Creating a Thread in Java Considered Expensive?. For more information, please follow other related articles on the PHP Chinese website!

Why can't the main class be found after copying and pasting the package in IDEA? Using IntelliJIDEA...

State synchronization between Java multi-interface calls: How to ensure that interface A is called after it is executed? In Java development, you often encounter multiple calls...

How to stop subsequent code execution when ID is repeated in Java programming. When learning Java programming, you often encounter such a requirement: when a certain condition is met,...

In-depth discussion of final consistency: In the distributed system of application scenarios and implementation methods, ensuring data consistency has always been a major challenge for developers. This article...

The troubleshooting idea of SSH connection failure after SpringBoot service has been running for a period of time has recently encountered a problem: a Spring...

How to push video streams from Hikvision camera SDK to front-end Vue project? During the development process, you often encounter videos that need to be captured by the camera to be circulated...

How to use access_token of OAuth2.0 to restrict interface access permissions How to ensure access_token when authorizing using OAuth2.0...

SpringBootRedis gets the key garbled problem analysis using Spring...


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Atom editor mac version download
The most popular open source editor

SublimeText3 Linux new version
SublimeText3 Linux latest version

SublimeText3 Mac version
God-level code editing software (SublimeText3)

SublimeText3 English version
Recommended: Win version, supports code prompts!

SAP NetWeaver Server Adapter for Eclipse
Integrate Eclipse with SAP NetWeaver application server.