Ejercicio de programación con Go: Selectores y mutexes: concurrencia y exclusión
0h 30m
Go: explora la concurrencia con selectores y mutexes. Este ejercicio te desafiará a gestionar notificaciones concurrentes y exclusión mutua en programación Go.
Este ejercicio de programación se centra en la implementación de un sistema de notificaciones en el lenguaje de programación Go, utilizando características avanzadas para el manejo de concurrencia, como select
para coordinar múltiples goroutines y sync.Mutex
para garantizar la exclusión mutua.
Se plantea crear tres goroutines que simulen diferentes fuentes de notificaciones, cada una enviando mensajes al programa principal de manera aleatoria a través de canales.
La tarea consiste en implementar un mecanismo que escuche estos canales concurrentemente, empleando select
para capturar y procesar los mensajes tan pronto como lleguen.
Además, es vital que el acceso a la lista compartida de mensajes procesados sea seguro, evitando condiciones de carrera a través del uso de sync.Mutex
.
Implementa un sistema de notificaciones en Go que utilice canales y select
para gestionar mensajes entrantes de diferentes fuentes de manera concurrente. Además, usa sync.Mutex
para proteger el acceso a una lista compartida de mensajes procesados.
Requisitos:
- Crea tres goroutines que simulen fuentes de notificaciones. Cada goroutine debe enviar un mensaje a través de un canal después de un tiempo aleatorio.
- Implementa un
select
en la función principal que escuche los mensajes de estos canales y añádalos a una lista compartida de mensajes procesados. - Asegúrate de proteger el acceso a la lista de mensajes procesados usando
sync.Mutex
para evitar condiciones de carrera. - Imprime la lista de mensajes procesados una vez que todas las goroutines hayan terminado de enviar mensajes.
Ejemplo de comportamiento esperado:
- Las goroutines envían mensajes aleatoriamente a diferentes intervalos.
- El programa añade los mensajes a la lista de manera concurrente.
- Al final, se imprime la lista completa de mensajes procesados.
Procesado: Mensaje 1 de la fuente 1
Procesado: Mensaje 1 de la fuente 3
Procesado: Mensaje 1 de la fuente 2
Procesado: Mensaje 2 de la fuente 1
Procesado: Mensaje 3 de la fuente 1
Procesado: Mensaje 2 de la fuente 3
Procesado: Mensaje 2 de la fuente 2
Procesado: Mensaje 3 de la fuente 2
Procesado: Mensaje 3 de la fuente 3
Todos los mensajes procesados: [Mensaje 1 de la fuente 1 Mensaje 1 de la fuente 3 Mensaje 1 de la fuente 2 Mensaje 2 de la fuente 1 Mensaje 3 de la fuente 1 Mensaje 2 de la fuente 3 Mensaje 2 de la fuente 2 Mensaje 3 de la fuente 2 Mensaje 3 de la fuente 3]
El orden de los mensajes pueden ser distinto al esperado.
Notas
- Se utiliza
sync.Mutex
para asegurar que solo una goroutine a la vez pueda modificar la listamensajesProcesados
.- El
select
permite escuchar múltiples canales simultáneamente, procesando mensajes tan pronto como estén disponibles.- La función
fuenteNotificaciones
simula la generación de mensajes desde diferentes fuentes.- Se utiliza un
waitGroup
para sincronizar la finalización de las goroutines y cerrar los canales adecuadamente.
Todos los ejercicios de programación de Go
Evalúa tus conocimientos con ejercicios de programación en Go de tipo Test, Puzzle, Código y Proyecto con VSCode.
Control de flujo y estructuras de bucle
Tipos de datos, variables y constantes
Composición de structs en lugar de herencia
Estructuras de control
Arrays y slices
Operadores y expresiones
Instalación Go primer programa
Errores personalizados y trazabilidad
Sistema API REST gestión de libros
Polimorfismo a través de Interfaces
Canales y comunicación entre Goroutines
Goroutines y concurrencia básica
Agenda de contactos por consola
Métodos HTTP con net/http
Métodos con receptores por valor y por puntero
Evaluación Go
Crear e invocar funciones
Estructuras structs
Introducción a Go
Estructuras de datos Mapas
Certificados de superación de Go
Supera todos los retos de Go y obtén estos certificados de superación para mejorar tu currículum y tu empleabilidad.
Tutorial para resolver este ejercicio de programación
Go
Selectores y Mutexes Concurrencia y Exclusión Mutua
Concurrencia y paralelismo