Descripción
Implementa un sistema de notificaciones concurrente utilizando select y sync.Mutex en Go para manejar mensajes desde diferentes fuentes simultáneamente, asegurando la exclusión mutua.
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.
Guarda tu progreso
Inicia sesión para no perder tu progreso y accede a miles de tutoriales, ejercicios prácticos y nuestro asistente de IA.
Más de 25.000 desarrolladores ya confían en CertiDevs
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.
Solución al ejercicio de programación en Go
¡Desbloquea la solución completa!
Completa el ejercicio de programación en Go para acceder a la solución paso a paso, explicaciones detalladas y mejores prácticas.
Practica con ejercicios de programación en Go
Mejora tus habilidades con cientos de ejercicios de práctica, recibe retroalimentación instantánea y obtén tu certificación cuando estés listo.
Asistente de IA
Aprende de tus errores
Progreso
Mide tu avance
Certificación
Valida tus habilidades
Únete a miles de desarrolladores mejorando sus habilidades en Go