mirror of
https://github.com/v2fly/v2ray-core.git
synced 2025-01-21 08:46:31 -05:00
25 lines
527 B
Go
25 lines
527 B
Go
|
package collect
|
||
|
|
||
|
type SizedQueue struct {
|
||
|
elements []interface{}
|
||
|
nextPos int
|
||
|
}
|
||
|
|
||
|
func NewSizedQueue(size int) *SizedQueue {
|
||
|
return &SizedQueue{
|
||
|
elements: make([]interface{}, size),
|
||
|
nextPos: 0,
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// Put puts a new element into the queue and pop out the first element if queue is full.
|
||
|
func (this *SizedQueue) Put(element interface{}) interface{} {
|
||
|
res := this.elements[this.nextPos]
|
||
|
this.elements[this.nextPos] = element
|
||
|
this.nextPos++
|
||
|
if this.nextPos == len(this.elements) {
|
||
|
this.nextPos = 0
|
||
|
}
|
||
|
return res
|
||
|
}
|