-
Notifications
You must be signed in to change notification settings - Fork 19
/
Copy pathev_data.go
86 lines (77 loc) · 1.43 KB
/
ev_data.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
73
74
75
76
77
78
79
80
81
82
83
84
85
86
package goev
import (
"sync"
)
type evData struct {
events uint32
fd int // 8 bits
eh EvHandler
}
type evDataMap struct {
arrSize int
arr []evData // 如果针对fd, 这里应该可以不用atomic, 直接保存value
// sync.Map is not suitable for use in evpoll as it is write-only, without read support
sMap map[int]*evData
mapMtx sync.Mutex
}
func newEvDataMap(arrSize int) *evDataMap {
if arrSize < 1 {
panic("evFdMaxSize < 1")
}
mapPreSize := arrSize / 9 // 1/10
if mapPreSize < 1 {
mapPreSize = 128
}
amu := &evDataMap{
arrSize: arrSize,
arr: make([]evData, arrSize),
sMap: make(map[int]*evData, mapPreSize),
}
return amu
}
func (dm *evDataMap) newOne(i int) *evData {
if i < dm.arrSize {
p := &(dm.arr[i])
if p.fd > 0 { // fd MUST > 0
panic("fd release fail!")
}
return p
}
return &evData{}
}
func (dm *evDataMap) load(i int) *evData {
if i < dm.arrSize {
p := &(dm.arr[i])
if p.fd < 1 {
return nil
}
return p
}
dm.mapMtx.Lock()
if v, ok := dm.sMap[i]; ok {
dm.mapMtx.Unlock()
return v
}
dm.mapMtx.Unlock()
return nil
}
func (dm *evDataMap) store(i int, v *evData) {
if i < dm.arrSize {
return
}
dm.mapMtx.Lock()
dm.sMap[i] = v
dm.mapMtx.Unlock()
}
func (dm *evDataMap) del(i int) {
if i < dm.arrSize {
p := &(dm.arr[i])
p.events = 0
p.fd = -1
p.eh = nil // release memory
return
}
dm.mapMtx.Lock()
delete(dm.sMap, i)
dm.mapMtx.Unlock()
}