Ir al contenido principal

Java Tip 28: hilos virtuales en Java


Con Java 21 entra un nuevo concepto: hilos virtuales java (Java Virtual Threads). 

La cual es una nueva característica que nos permite crear miles o millones de hilos (tareas en paralelo). Los cuales se diferencian de los hilos comunes (Platform Threads) al no depender del sistema operativo, puesto que son virtuales. De estos se encargará la JVM.

Al usar hilos virtuales ahorramos recursos del procesador y de memoria del sistema, sin importar si estamos creando y/o usando miles o millones.

Los hilos virtuales son ideales para aplicaciones modernas donde se requiere esperar y recibir respuestas o acceder a bases de datos remotas, entre otras cosas. Además no impide usar los hilos comunes que dependen del sistema operativo.

Observemos un ejemplo de uso de hilos virtuales.

VirtualThreadsDemo.java

package com.comunidad.demo;

public class VirtualThreadsDemo {
    public static void main(String[] args) throws InterruptedException {
        // Crear un Virtual Thread
        Thread.startVirtualThread(() -> {
            System.out.println("Hola desde un Virtual Thread!");
        });

        // Crear varios Virtual Threads en un loop
        for (int i = 0; i < 5; i++) {
            Thread.startVirtualThread(() -> {
                System.out.println("Ejecutando tarea en hilo virtual: " + Thread.currentThread());
            });
        }

        // Pausa para que los hilos terminen
        Thread.sleep(1000);
    }
}

Al usar Java Virtual Threads se crea un hilo virtual en lugar de uno del sistema operativo. Se pueden lanzar miles de estos hilos sin problemas de rendimiento y el código se mantiene simple y parecido al modelo clásico de hilos.

Ahora veamos un ejemplo con hilos clásicos que dependen del sistema operativo:

PlatformThreadsDemo.java

package com.comunidad.demo;

public class PlatformThreadsDemo {
    public static void main(String[] args) throws InterruptedException {
        // Crear un hilo clásico
        Thread hilo = new Thread(() -> {
            System.out.println("Hola desde un hilo normal!");
        });
        hilo.start();

        // Crear varios hilos en un loop
        for (int i = 0; i < 5; i++) {
            Thread t = new Thread(() -> {
                System.out.println("Ejecutando tarea en hilo normal: " + Thread.currentThread());
            });
            t.start();
        }

        // Pausa para que los hilos terminen
        Thread.sleep(1000);
    }
}

La diferencia clave es que aquí los hilos son gestionados directamente por el sistema operativo, lo que implica mayor consumo de recursos y limitaciones en la cantidad que se pueden crear simultáneamente.

Esta nueva característica de Java no impide usar hilos dependientes del sistema, se pueden usar simultáneamente.

Si necesitas realizar cálculos intensivos sin necesidad de una respuesta rápida puedes optar por hilos dependientes del sistema operativo.

Si necesitas operaciones I/O simultáneas, los hilos virtuales Java son tu opción. Además de que se recomiendan para aplicaciones hechas con Spring Boot o frameworks similares (Quarkus, Helidon y Micronaut).

Enlaces:

https://www.arquitecturajava.com/java-virtual-threads-que-son-y-por-que-son-importantes/
https://www.paradigmadigital.com/dev/ventajas-virtual-threads-java-21/
https://www.campusmvp.es/recursos/post/hilos-virtuales-en-java-la-revolucion-del-rendimiento-en-la-plataforma-java.aspx?srsltid=AfmBOorK0ohCewbpSKEaSfcEHE7o2cjDPmosxo-n2lE2edqBYUv20EVY

Comentarios

Entradas populares de este blog

Java Tip 1: Importaciones por default

Tip 1 : Todas las clases del paquete java.lang se importan por defecto. Podríamos hacer algo como esto: import java.lang.System ; import java.lang.String ; import java.lang.Boolean ; import java.lang.Integer ; import java.lang.Short ; import java.lang.StringBuilder ; import java.lang.StringBuffer ; O cosas (aberrantes) como: //Traernos todas las clases del paquete java.lang import java.lang.* ; Sin embargo, no es necesario. Repitamos esto como un mantra: Todas las clases del paquete  java.lang  se importan por defecto, no es necesario escribir de más .

Java Tip 20: JDBC (2da parte)

Continuamos con esta serie sobre JDBC . Como dijimos la vez anterior JDBC( Java Database Connectivity ) es el estándar de conectividad de bases de datos de Java y proporciona un mecanismo para que los programas Java se conecten a las bases de datos. En este post veremos ejemplos de su uso. Requisitos: Tener nociones de Java.  Tener nociones de SQL (usaremos H2). Tener nociones de Maven. Creando una aplicación JDBC Crearemos una sencilla aplicación que se conecte a una BD H2 (ver  tutorial ). Pasos: Crearemos una tabla a la que llamaremos Cursos. La cual tendrá los siguientes campos: id, titulo, materia, instructor, fecha y hora. Crear la aplicación Java usando Maven. Crearemos instrucciones SQL para consultar la información, ingresar nuevos cursos, actualizar y eliminar registros. Ejecutar la aplicación con Maven. 1. Creamos la tabla con sus seis campos (agregaremos los datos con la aplicación Java): CREATE OR REPLACE TABLE CURSOS( id bigint ...

Java Tip 26: Stream API

La Stream API de Java sirve para procesar colecciones de datos de forma declarativa y funcional, evitando bucles explícitos y haciendo el código más legible, conciso y fácil de paralelizar. Los Streams representan una secuencia de elementos sobre la cual se pueden aplicar operaciones como filtrar, transformar, ordenar o reducir. No almacenan datos: simplemente transportan valores desde una fuente (colección, arreglo, I/O, etc.) a través de una pipeline de operaciones.   Permiten escribir código más expresivo y funcional, similar a otros lenguajes modernos. Operaciones principales Los Streams se dividen en dos tipos de operaciones: Intermedias (devuelven otro Stream): filter() → filtra elementos según una condición.   map() → transforma cada elemento.   sorted() → ordena los elementos. Terminales (devuelven un resultado): collect() → convierte el Stream en una colección.   forEach() → recorre los elementos.   red...