My previous article focussed on comparing solutions for performing parallel execution using Spring Core Reactor and JDK 21. This article will follow m

Parallel processing with Virtual Threads - A comparative analysis

submited by
Style Pass
2025-01-12 00:30:02

My previous article focussed on comparing solutions for performing parallel execution using Spring Core Reactor and JDK 21. This article will follow my previous article where I will provide comparative analysis of Virtual Threads based execution for Spring Core Reactor and JDK 21 based implementation.

Keeping the same use case that we referred to for comparing Spring Core Reactor & JDK based implementation, this article will be focussing on:

Contemporary applications that are throughput and latency sensitive, demand high concurrency without overwhelming system resources

Virtual Threads, a feature of Project Loom in JDK 21 offers lightweight, scalable threads that are managed by JVM. Unlike OS threads, they are cheap to create, block, and manage, making them ideal for high-concurrency applications.

For any thread within an application, its primary task is to perform CPU or I/O bound operations. While virtual threads can be used for both type of operations, one should be mindful of the fact that Virtual Threads are more appropriate for I/O intensive operations. Having said that, it can still be used for CPU intensive operations, but the benefits might not be proportionate to the gain we may see in I/O bound operations.

Leave a Comment