As goroutines e canais do Go permitem um conjunto de padrões de concorrência bem estabelecidos que resolvem problemas comuns — distribuindo trabalho, fan-out/fan-in, pipelines e rate limiting. Conhecer esses padrões idiomáticos permite construir sistemas concorrentes corretos e eficientes.
Worker pool — bounded concurrency
{
wg sync.WaitGroup
w := ; w < numWorkers; w++ {
wg.Add()
{
wg.Done()
job := jobs {
results <- process(job)
}
}()
}
wg.Wait()
(results)
}
