Selectores y mutexes: concurrencia y exclusión

Código
Experto
Go
Curso de Go
30 min
50 XP
Actualizado: 08/11/2024

¡Programa y certifícate!

Asistente de IA
Solución de código
Certificado
Empezar ejercicio

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.

Progreso guardado
Asistente IA
Ejercicios
Iniciar sesión gratis

Más de 25.000 desarrolladores ya confían en CertiDevs

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.

Solución al ejercicio de programación en Go

Contenido bloqueado

¡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.

solution.js
JavaScript
1 function solveChallenge ( input ) {
2 // Algoritmo optimizado O(n log n)
3 const data = parseInput ( input );
4 const sorted = data . sort (( a , b ) => a - b );
5
6 // Aplicar técnica de dos punteros
7 let left = 0 , right = sorted . length - 1 ;
8 const result = [];
9
10 while ( left < right ) {
11 const sum = sorted [ left ] + sorted [ right ];
12 if ( sum === target ) {
13 result . push ([ sorted [ left ], sorted [ right ]]);
14 left ++; right --;
15 } else if ( sum < target ) {
16 left ++;
17 } else {
18 right --;
19 }
20 }
21
22 return result ;
23 }
Código completo
Explicaciones
Mejores prácticas
+1.200 developers han resuelto este ejercicio de programación

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

⭐⭐⭐⭐⭐
4.9/5 valoración