blob: ade5cce649b40c720ed7892560540693a422d267 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
|
package main
import (
"fmt"
"sync"
"time"
)
func main() {
var (
jobs = 20 // Run 20 jobs in total.
running = make(chan bool, 3) // Limit concurrent jobs to 3.
wg sync.WaitGroup // Keep track of which jobs are finished.
)
wg.Add(jobs)
for i := 1; i <= jobs; i++ {
running <- true // Fill running; this will block and wait if it's already full.
// Start a job.
go func(i int) {
defer func() {
<-running // Drain running so new jobs can be added.
wg.Done() // Signal that this job is done.
}()
// "do work"
time.Sleep(1 * time.Second)
fmt.Println(i)
}(i)
}
wg.Wait() // Wait until all jobs are done.
fmt.Println("done")
}
|