Ejercicio de programación con Go: Selectores y mutexes: concurrencia y exclusión

Código
Práctica
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:

  1. 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.
  2. 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.
  3. Asegúrate de proteger el acceso a la lista de mensajes procesados usando sync.Mutex para evitar condiciones de carrera.
  4. 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 lista mensajesProcesados.
  • 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.
Empezar ejercicio de programación

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.

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

Go

Selectores y Mutexes Concurrencia y Exclusión Mutua

Concurrencia y paralelismo

Otros tutoriales de programación con Go