Skip to content

Generic Queue implementation in Go using linked list

License

Notifications You must be signed in to change notification settings

sv-tools/gqueue

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

6 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

gqueue

Generic Queue implementation in Go using linked list

Usage

s := gqueue.New(1, 2, 3, 4)
fmt.Println(s.Len())
fmt.Println(s.Pop())
fmt.Println(s.Pop())
fmt.Println(s.Pop())
fmt.Println(s.Pop())
s.Push(5)
fmt.Println(s.Peek())
// Output: 4
// 1
// 2
// 3
// 4
// 5

Changelog

v0.1.0

  • minimal supported version of Go is 1.20
  • initial implementation

v1.0.0

  • minimal supported version of Go is 1.23
  • added Iter method to iterate over the queue and consume all items
s := gqueue.New(1, 2, 3, 4)
for v := range s.Iter() {
    fmt.Println(v)
}
fmt.Println("len:", s.Len())
// Output: 1
// 2
// 3
// 4
// len: 0

v1.1.0

  • added IsEmpty method to check if the queue is empty

About

Generic Queue implementation in Go using linked list

Resources

License

Stars

Watchers

Forks

Languages