Involved Source Files Package list implements a doubly linked list.
To iterate over a list (where l is a *List):
for e := l.Front(); e != nil; e = e.Next() {
// do something with e.Value
}
Code Examples
package main
import (
"container/list"
"fmt"
)
func main() {
// Create a new list and put some numbers in it.
l := list.New()
e4 := l.PushBack(4)
e1 := l.PushFront(1)
l.InsertBefore(3, e4)
l.InsertAfter(2, e1)
// Iterate through list and print its contents.
for e := l.Front(); e != nil; e = e.Next() {
fmt.Println(e.Value)
}
}
List represents a doubly linked list.
The zero value for List is an empty list ready to use. Back returns the last element of list l or nil if the list is empty. Front returns the first element of list l or nil if the list is empty. Init initializes or clears list l. InsertAfter inserts a new element e with value v immediately after mark and returns e.
If mark is not an element of l, the list is not modified.
The mark must not be nil. InsertBefore inserts a new element e with value v immediately before mark and returns e.
If mark is not an element of l, the list is not modified.
The mark must not be nil. Len returns the number of elements of list l.
The complexity is O(1). MoveAfter moves element e to its new position after mark.
If e or mark is not an element of l, or e == mark, the list is not modified.
The element and mark must not be nil. MoveBefore moves element e to its new position before mark.
If e or mark is not an element of l, or e == mark, the list is not modified.
The element and mark must not be nil. MoveToBack moves element e to the back of list l.
If e is not an element of l, the list is not modified.
The element must not be nil. MoveToFront moves element e to the front of list l.
If e is not an element of l, the list is not modified.
The element must not be nil. PushBack inserts a new element e with value v at the back of list l and returns e. PushBackList inserts a copy of another list at the back of list l.
The lists l and other may be the same. They must not be nil. PushFront inserts a new element e with value v at the front of list l and returns e. PushFrontList inserts a copy of another list at the front of list l.
The lists l and other may be the same. They must not be nil. Remove removes e from l if e is an element of list l.
It returns the element value e.Value.
The element must not be nil.
func New() *List
func (*List).Init() *List
func (*List).PushBackList(other *List)
func (*List).PushFrontList(other *List)
Package-Level Functions (only one)
New returns an initialized list.
The pages are generated with Goldsv0.7.3. (GOOS=linux GOARCH=amd64)
Golds is a Go 101 project developed by Tapir Liu.
PR and bug reports are welcome and can be submitted to the issue list.
Please follow @zigo_101 (reachable from the left QR code) to get the latest news of Golds.