代码拉取完成,页面将自动刷新
同步操作将从 JUMEI_ARCH/volantmq 强制同步,此操作会覆盖自 Fork 仓库以来所做的任何修改,且无法恢复!!!
确定后同步将在后台操作,完成时将刷新页面,请耐心等待。
package connection
import (
"errors"
"sync"
"sync/atomic"
"github.com/troian/surgemq/packet"
)
type packetsFlowControl struct {
counter uint64
quit chan struct{}
cond *sync.Cond
inUse map[packet.IDType]bool
sendQuota int32
preserveOrder bool
}
func newFlowControl(quit chan struct{}, preserveOrder bool) *packetsFlowControl {
return &packetsFlowControl{
inUse: make(map[packet.IDType]bool),
cond: sync.NewCond(new(sync.Mutex)),
quit: quit,
preserveOrder: preserveOrder,
}
}
func (s *packetsFlowControl) acquire() (packet.IDType, error) {
defer s.cond.L.Unlock()
s.cond.L.Lock()
if (s.preserveOrder && !atomic.CompareAndSwapInt32(&s.sendQuota, 0, 1)) ||
(atomic.AddInt32(&s.sendQuota, -1) == 0) {
s.cond.Wait()
select {
case <-s.quit:
return 0, errors.New("exit")
default:
}
}
var id packet.IDType
for count := 0; count <= 0xFFFF; count++ {
s.counter++
id = packet.IDType(s.counter)
if _, ok := s.inUse[id]; !ok {
s.inUse[id] = true
break
}
}
return id, nil
}
//func (s *packetsFlowControl) reAcquire(id message.IDType) error {
// defer s.lock.Unlock()
// s.lock.Lock()
//
// if (s.preserveOrder && !atomic.CompareAndSwapInt32(&s.sendQuota, 0, 1)) ||
// (atomic.AddInt32(&s.sendQuota, -1) == 0) {
// s.cond.Wait()
// select {
// case <-s.quit:
// return errors.New("exit")
// default:
// }
// }
//
// s.inUse[id] = true
//
// return nil
//}
func (s *packetsFlowControl) release(id packet.IDType) {
defer func() {
atomic.AddInt32(&s.sendQuota, -1)
s.cond.Signal()
}()
defer s.cond.L.Unlock()
s.cond.L.Lock()
delete(s.inUse, id)
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。