-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathtaskpool.go
More file actions
49 lines (41 loc) · 795 Bytes
/
taskpool.go
File metadata and controls
49 lines (41 loc) · 795 Bytes
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
36
37
38
39
40
41
42
43
44
45
46
47
48
49
package quartz
import (
"context"
"sync"
)
type HandlerFunc func(ctx context.Context)
type TaskPool struct {
wg sync.WaitGroup
taskChannel chan HandlerFunc
maxThread int
cancel context.CancelFunc
}
func NewTaskPool() *TaskPool {
ctx, cancelFunc := context.WithCancel(context.Background())
tp := &TaskPool{
wg: sync.WaitGroup{},
taskChannel: make(chan HandlerFunc),
maxThread: 10,
cancel: cancelFunc,
}
for i := 0; i < tp.maxThread; i++ {
go func() {
for {
select {
case fn := <-tp.taskChannel:
fn(ctx)
case <-ctx.Done():
return
}
}
}()
}
return tp
}
func (t *TaskPool) Submit(handlerFunc HandlerFunc) {
t.taskChannel <- handlerFunc
}
func (t *TaskPool) Stop() {
t.cancel()
close(t.taskChannel)
}