Go语言的列表list

2020-01-31  本文已影响0人  码二哥

参考:
http://c.biancheng.net/view/35.html

关键点

列表list内部是双链表

列表能够高效地进行任意位置的元素插入删除操作

可以通过newvar 进行声明列表

列表的元素类型,没有限制

list的使用场景

各种类型的元素 组成时,可以使用列表list

在Go语言中,列表使用 container/list 包来实现,内部的实现原理是双链表。

1、初始化列表

list 的初始化有两种方法:
分别是使用

两种方法的初始化效果都是一致的。

  1. 通过 container/list 包的New() 函数初始化 list

变量名 := list.New()

  1. 通过 var 关键字声明初始化 list

var 变量名 list.List

2、列表切片和 map不同的是,

列表并没有具体元素类型限制,因此,列表的元素可以是任意类型,这既带来了便利,

也引来一些问题,例如给列表中放入了一个 interface{} 类型的值,取出值后,

如果要将 interface{} 转换为其他类型将会发生宕机

3、在列表中插入元素

双链表支持从队列前方或后方插入元素,分别对应的方法是

提示
这两个方法都会返回一个 *list.Element 结构,如果在以后的使用中需要删除插入的元素,则只能通过 *list.Element 配合 Remove() 方法进行删除,这种方法可以让删除更加效率化,同时也是双链表特性之一。

下面代码展示如何给 list

l := list.New()
l.PushBack("fist")
l.PushFront(67)

代码说明如下:

image

4、从列表中删除元素

列表插入函数的返回值会提供一个 *list.Element 结构,这个结构记录着列表元素的值以及与其他节点之间的关系等信息,从列表中删除元素时,需要用到这个结构进行快速删除。

列表操作元素:

package main
import "container/list"
func main() {
    l := list.New()
    // 尾部添加
    l.PushBack("canon")
    // 头部添加
    l.PushFront(67)
    // 尾部添加后保存元素句柄
    element := l.PushBack("fist")
    // 在fist之后添加high
    l.InsertAfter("high", element)
    // 在fist之前添加noon
    l.InsertBefore("noon", element)
    // 使用
    l.Remove(element)
}

代码说明如下:

下表中展示了每次操作后列表的实际元素情况。

列表元素操作的过程

5、遍历列表——访问列表的每一个元素

遍历双链表需要配合 Front() 函数获取头元素,遍历时只要元素不为空就可以继续进行,每一次遍历都会调用元素的 Next() 函数,代码如下所示。

l := list.New()
// 尾部添加
l.PushBack("canon")
// 头部添加
l.PushFront(67)
for i := l.Front(); i != nil; i = i.Next() {
    fmt.Println(i.Value)
}

代码输出如下:

67
canon

代码说明如下:

上一篇 下一篇

猜你喜欢

热点阅读