I am working with Java 19. I have tried to use newly introduced virtual threads as follows:
public static void main(String[] args) {
System.out.println("Started with virutal threads");
try (ExecutorService virtualService = Executors.newVirtualThreadPerTaskExecutor()) {
virtualService.submit(() -> System.out.println("[" + Thread.currentThread().getName() + "] virtual task 1"));
virtualService.submit(() -> System.out.println("[" + Thread.currentThread().getName() + "] virtual task 2"));
}
System.out.println("Finished");
}
The output of this program is:
Started with virutal threads
[] virtual task 2
[] virtual task 1
Finished
Why Thread.currentThread().getName() does not have any name?
Followup question: How to identify virtual threads between eachother? (how to recognize them) So the output would look like
[thread-1] virtual task 2
[thread-0] virtual task 1
tl;dr
Thread name optional
The name of any thread is entirely optional.
You may name a thread if you so desire. This can be handy while debugging. But you should not expect any preset value.
Virtual threads in particular are specified as having no set name. To quote the Javadoc (my emphasis):
Some frameworks, such as JavaFX/OpenJFX, give their threads an informative name.
Thread ID
If you want to identify a
Thread
, use its ID, along
.Thread#threadId
.Thread#getId
To quote the Javadoc: