skip limiting if limit is zero

This commit is contained in:
Chris Lu 2021-04-04 18:38:30 -07:00
parent 8251d1140e
commit fbb82a5c9c

View file

@ -85,16 +85,20 @@ func NewLimitedOutOfOrderProcessor(limit int32) (c *LimitedOutOfOrderProcessor)
request := value.Interface().(OperationRequest) request := value.Interface().(OperationRequest)
c.processorLimitCond.L.Lock() if c.processorLimit > 0 {
for atomic.LoadInt32(&c.currentProcessor) > c.processorLimit { c.processorLimitCond.L.Lock()
c.processorLimitCond.Wait() for atomic.LoadInt32(&c.currentProcessor) > c.processorLimit {
c.processorLimitCond.Wait()
}
atomic.AddInt32(&c.currentProcessor, 1)
c.processorLimitCond.L.Unlock()
} }
atomic.AddInt32(&c.currentProcessor, 1)
c.processorLimitCond.L.Unlock()
go func() { go func() {
defer atomic.AddInt32(&c.currentProcessor, -1) if c.processorLimit > 0 {
defer c.processorLimitCond.Signal() defer atomic.AddInt32(&c.currentProcessor, -1)
defer c.processorLimitCond.Signal()
}
request() request()
}() }()