提交引擎优化

This commit is contained in:
duanhf2012
2020-03-13 14:48:05 +08:00
parent 3854b5f6c2
commit 686d88cabc
2 changed files with 27 additions and 5 deletions

View File

@@ -30,7 +30,9 @@ type MsgProcessor struct {
}
func (slf *MsgProcessor) InitProcessor(){
slf.mapMsg = make(map[uint16]MessageInfo)
}
func (slf *MsgProcessor) RegMessage(msgtype uint16,msg proto.Message,handle MessageHandler){
var info MessageInfo

View File

@@ -2,9 +2,9 @@ package util
import (
"fmt"
"sync"
"github.com/duanhf2012/origin/util/hash"
"sync"
"sync/atomic"
)
const (
@@ -16,6 +16,7 @@ type MapEx struct {
m []map[interface{}]interface{}
l []sync.RWMutex
hashMapNum int
rangeIdx uint32
}
func (m *MapEx) Init(hashMapNum int) {
@@ -36,6 +37,19 @@ func NewMapEx() *MapEx {
return &mapEx
}
func (m *MapEx) NextRLockRange(f func(key interface{}, value interface{})) {
i := atomic.AddUint32(&m.rangeIdx,1)%uint32(m.hashMapNum)
m.l[i].RLock()
for key, val := range m.m[i] {
f(key, val)
}
m.l[i].RUnlock()
}
func (m *MapEx) ClearMap() {
for i := 0; i < DEFAULT_SAFE_MAP_MAX_HASH_NUM; i++ {
m.l[i].Lock()
@@ -197,9 +211,15 @@ func (m *MapEx) LockSet(key interface{}, f func(value interface{}) interface{})
ret, ok := val[key]
if ok == false {
val[key] = f(nil)
ret := f(nil)
if ret != nil {
val[key] =ret
}
} else {
val[key] = f(ret)
ret := f(ret)
if ret != nil {
val[key] =ret
}
}
m.l[idx].Unlock()