POLITICA DE COOKIES

Q2BSTUDIO.COM utiliza cookies técnicas, analíticas, de sesión y de publicidad con la finalidad de prestar un mejor servicio. No obstante, necesitamos su consentimiento explícito para poder utilizarlas. Así mismo puede cambiar la configuración de las cookies u obtener más información aquí .

Concurrencia de Java: Parte III - FutureTask

Concurrencia en Java con FutureTask: guía práctica de FutureTask, Callable, Future y ExecutorService, con buenas prácticas

Publicado el 08/09/2025

Nota: obtener el código fuente en https://gitlab.com/som.mukhopadhyay/FutureTask

En esta entrega sobre concurrencia en Java abordamos FutureTask y cómo se integra con Callable, Future y ExecutorService. FutureTask es una clase que representa un cálculo asíncrono cancelable y ofrece una implementación base de Future con métodos para iniciar y cancelar el cálculo, comprobar si ha terminado y recuperar su resultado.

Callable y Runnable definen unidades de trabajo. La diferencia clave es que Callable puede devolver un resultado mientras que Runnable no. Al enviar una tarea Callable a un ExecutorService se obtiene de inmediato un objeto Future o FutureTask que permite consultar el estado de la tarea. El método isDone indica si la tarea ha terminado. El método get devuelve el resultado, pero es bloqueante, por lo que si la tarea no ha finalizado la llamada al get detendrá el hilo hasta la finalización o la cancelación.

FutureTask normalmente se utiliza a través de ExecutorService y sus implementaciones que gestionan pools de hilos reutilizables y permiten lanzar tareas asíncronas sin crear hilos manualmente.

Ejemplo conceptual del diseño usado en el artículo original: una clase ProductInfo que representa nombre y precio, una clase Preloader que lanza en segundo plano la carga de una lista de ProductInfo mediante una Callable llamada LoadProductInfo, y una clase Main que inicia el preloader, comprueba periódicamente si la tarea ha terminado, y finalmente obtiene los datos con future.get. Preloader expone métodos como start para enviar la tarea al ExecutorService, isDone para comprobar estado, get para recuperar la lista (bloqueante) y cancel para abortar la tarea.

Comportamientos importantes a tener en cuenta: si se llama a get antes de que la tarea termine el hilo queda bloqueado; cancel con true intenta interrumpir la ejecución; comprobar isDone permite realizar otras tareas mientras esperamos; usar un pool de hilos evita la sobrecarga de crear hilos continuamente.

Consideraciones prácticas en producción: usar excepciones para manejar InterruptedException y ExecutionException, cerrar correctamente el ExecutorService con shutdown, definir tiempos de espera cuando sea necesario para evitar esperas indefinidas, y diseñar tareas que respondan a interrupciones para que cancel funcionar de forma efectiva.

En Q2BSTUDIO, empresa de desarrollo de software y aplicaciones a medida, aplicamos estas prácticas de concurrencia para construir sistemas escalables y robustos. Si necesita soluciones de software a medida o aplicaciones a medida creadas para su negocio, conozca nuestro enfoque en desarrollo de aplicaciones y software multiplataforma. Además integramos capacidades de inteligencia artificial y agentes IA para automatizar procesos y mejorar toma de decisiones; vea nuestras soluciones de inteligencia artificial.

Palabras clave y servicios relacionados: aplicaciones a medida, software a medida, inteligencia artificial, ciberseguridad, servicios cloud aws y azure, servicios inteligencia de negocio, ia para empresas, agentes IA, power bi. Ofrecemos proyectos que combinan concurrencia eficiente en backend con analítica y visualización tipo power bi para soluciones completas de inteligencia de negocio.

Resumen y recomendaciones: utilice FutureTask y ExecutorService cuando necesite ejecutar tareas asíncronas que devuelvan resultados; prefiera Callable para trabajos que retornen datos; controle bloqueo con timeouts cuando llame a get; implemente cancelaciones cooperativas y diseñe tareas sensibles a la interrupción. Con estas prácticas se logra una arquitectura concurrente fiable y fácil de mantener, ideal para aplicaciones empresariales complejas y para integrar servicios cloud, ciberseguridad y soluciones de inteligencia de negocio.

Fin del artículo, inicio de la diversión
Construyendo software juntos

Dando vida a tus ideas desde 2008

Diseñamos aplicaciones móviles y de escritorio innovadoras que cumplen con tus requisitos específicos y mejoran la eficiencia operativa.
Más info
Cuéntanos tu visión
Sea cual sea el alcance, podemos convertir tu idea en realidad. Envíanosla y charlemos sobre tu proyecto o una colaboración futura.
Contáctanos
artículos destacados
Live Chat
Enviado correctamente.

Gracias por confiar en Q2BStudio