优化延迟无锁队列,增加迭代器方法

This commit is contained in:
fantasticbin 2024-12-03 13:01:11 +08:00
parent 0ec5a62438
commit 210b60011e
2 changed files with 31 additions and 10 deletions

View File

@ -1,6 +1,9 @@
package lock_free package lock_free
import "time" import (
"iter"
"time"
)
type DelayLkQueue[T any] struct { type DelayLkQueue[T any] struct {
LkQueue[T] LkQueue[T]
@ -18,15 +21,33 @@ func (q *DelayLkQueue[T]) DelayEnqueue(value T, duration time.Duration) {
}) })
} }
// ContinuousDequeue 持续监听出队通知 // ContinuousDequeue 持续监听出队
func (q *DelayLkQueue[T]) ContinuousDequeue(notify ...chan T) { func (q *DelayLkQueue[T]) ContinuousDequeue() iter.Seq[T] {
return func(yield func(T) bool) {
for { for {
if value, ok := q.Dequeue(); ok { if value, ok := q.Dequeue(); ok {
for _, n := range notify { if !yield(value) {
n <- value return
} }
} else { } else {
time.Sleep(time.Millisecond) // 队列为空休眠1毫秒 time.Sleep(time.Millisecond) // 队列为空休眠1毫秒
} }
} }
}
}
// ContinuousDequeueExecute 持续监听出队执行函数
func (q *DelayLkQueue[T]) ContinuousDequeueExecute(fn func(T)) {
for value := range q.ContinuousDequeue() {
fn(value)
}
}
// ContinuousDequeueNotify 持续监听出队通知
func (q *DelayLkQueue[T]) ContinuousDequeueNotify(chs ...chan T) {
q.ContinuousDequeueExecute(func(value T) {
for _, ch := range chs {
ch <- value
}
})
} }

View File

@ -27,7 +27,7 @@ func TestDelayLkQueue(t *testing.T) {
} }
}() }()
go q.ContinuousDequeue(notify) go q.ContinuousDequeueNotify(notify)
time.Sleep(time.Second * 5) time.Sleep(time.Second * 5)
close(notify) close(notify)
} }