不可能使用容器/列表列表类型构造循环。List 类型方法确保没有循环。因为列表Element的 next 和 previous 指针没有导出,应用程序无法通过直接修改元素来创建循环。


您可以定义自己的类型来创建带有循环的列表:


package main


import "fmt"


type node struct {

    v    int

    next *node

}


func main() {

    // Create list with 1, 2, 3 and print.


    l := &node{1, &node{2, &node{3, nil}}}

    for n := l; n != nil; n = n.next {

        fmt.Println(n.v)

    }


    // Create list with loop and print at most 100 steps down the list.


    n3 := &node{3, nil}

    l = &node{1, &node{2, n3}}

    n3.next = l


    for i, n := 0, l; n != nil && i < 100; n, i = n.next, i+1 {

        fmt.Println(n.v)

    }


}