2024-12-03 10:10:02 +08:00
|
|
|
package lock_free
|
|
|
|
|
|
|
|
import "time"
|
|
|
|
|
|
|
|
type DelayLkQueue[T any] struct {
|
2024-12-03 11:14:58 +08:00
|
|
|
gap time.Duration // 控制监听重试间隔
|
2024-12-03 10:10:02 +08:00
|
|
|
LkQueue[T]
|
|
|
|
}
|
|
|
|
|
2024-12-03 10:25:34 +08:00
|
|
|
// NewDelayLkQueue 创建延迟无锁队列
|
2024-12-03 11:14:58 +08:00
|
|
|
func NewDelayLkQueue[T any](opt ...Option) *DelayLkQueue[T] {
|
|
|
|
opts := loadOptions(opt...)
|
|
|
|
return &DelayLkQueue[T]{opts.gap, *NewLkQueue[T]()}
|
2024-12-03 10:25:34 +08:00
|
|
|
}
|
|
|
|
|
2024-12-03 10:10:02 +08:00
|
|
|
// DelayEnqueue 延迟入队
|
|
|
|
func (q *DelayLkQueue[T]) DelayEnqueue(value T, duration time.Duration) {
|
|
|
|
time.AfterFunc(duration, func() {
|
|
|
|
q.Enqueue(value)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
// ContinuousDequeue 持续监听出队通知
|
|
|
|
func (q *DelayLkQueue[T]) ContinuousDequeue(notify ...chan T) {
|
|
|
|
for {
|
2024-12-03 10:32:08 +08:00
|
|
|
if value, ok := q.Dequeue(); ok {
|
|
|
|
for _, n := range notify {
|
|
|
|
n <- value
|
|
|
|
}
|
|
|
|
} else {
|
2024-12-03 11:14:58 +08:00
|
|
|
time.Sleep(q.gap) // 队列为空,休眠重试
|
2024-12-03 10:10:02 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|