-
Notifications
You must be signed in to change notification settings - Fork 1
/
coroutine.go
72 lines (59 loc) · 1.25 KB
/
coroutine.go
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
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
// Package coroutine 协程处理程序
// 处理等待协程等
package coroutine
import (
"reflect"
"sync"
"github.com/freshcn/log"
)
// Group 主处理组
type Group struct {
wait sync.WaitGroup
}
// Default 默认的处理组
var Default = Group{}
// add 添加一个新的等待项
func (g *Group) add(nums ...int) {
var num = 1
if len(nums) > 0 {
num = nums[0]
}
g.wait.Add(num)
}
// done 完成一个等待
func (g *Group) done() {
g.wait.Done()
}
// Wait 等候完成
func (g *Group) Wait() {
g.wait.Wait()
}
// Run 运行一个协程
// handler 是要运行的处理函数,可以接受多个参数
// parames 需要发给handler接受的参数,顺序和函数需要接受的顺序一样
func (g *Group) Run(handler interface{}, parames ...interface{}) bool {
defer func() {
if err := recover(); err != nil {
log.Error(err)
}
}()
var (
handlerFUNC = reflect.ValueOf(handler)
handlerParames = make([]reflect.Value, len(parames))
)
if handlerFUNC.Kind() != reflect.Func {
return false
}
if len(parames) > 0 {
for i, v := range parames {
handlerParames[i] = reflect.ValueOf(v)
}
}
// 开始运行一个新的协程
g.add()
go func() {
defer g.done()
handlerFUNC.Call(handlerParames)
}()
return true
}