github.com/yaling888/clash@v1.53.0/common/queue/queue.go (about) 1 package queue 2 3 import ( 4 "sync" 5 6 "github.com/samber/lo" 7 ) 8 9 // Queue is a simple concurrent safe queue 10 type Queue[T any] struct { 11 items []T 12 lock sync.RWMutex 13 } 14 15 // Put add the item to the queue. 16 func (q *Queue[T]) Put(items ...T) { 17 if len(items) == 0 { 18 return 19 } 20 21 q.lock.Lock() 22 q.items = append(q.items, items...) 23 q.lock.Unlock() 24 } 25 26 // Pop returns the head of items. 27 func (q *Queue[T]) Pop() T { 28 if len(q.items) == 0 { 29 return lo.Empty[T]() 30 } 31 32 q.lock.Lock() 33 head := q.items[0] 34 q.items = q.items[1:] 35 q.lock.Unlock() 36 return head 37 } 38 39 // Last returns the last of item. 40 func (q *Queue[T]) Last() T { 41 if len(q.items) == 0 { 42 return lo.Empty[T]() 43 } 44 45 q.lock.RLock() 46 last := q.items[len(q.items)-1] 47 q.lock.RUnlock() 48 return last 49 } 50 51 // Copy get the copy of queue. 52 func (q *Queue[T]) Copy() []T { 53 items := []T{} 54 q.lock.RLock() 55 items = append(items, q.items...) 56 q.lock.RUnlock() 57 return items 58 } 59 60 // Len returns the number of items in this queue. 61 func (q *Queue[T]) Len() int64 { 62 q.lock.Lock() 63 defer q.lock.Unlock() 64 65 return int64(len(q.items)) 66 } 67 68 // New is a constructor for a new concurrent safe queue. 69 func New[T any](hint int64) *Queue[T] { 70 return &Queue[T]{ 71 items: make([]T, 0, hint), 72 } 73 }