博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Go标准容器之List
阅读量:6339 次
发布时间:2019-06-22

本文共 4192 字,大约阅读时间需要 13 分钟。

简介

Go的标准包container中包含了常用的容器类型,包括conatiner/list,container/heap,container/ring。本篇介绍conatiner/list

conatiner/list实现了一个双向链表。使用起来与其他语言的动态列表非常相似,3秒钟便可入门。

3秒钟入门

package mainimport ("container/list""fmt")func main() {nums := list.New()nums.PushBack(1)nums.PushBack(2)nums.PushBack(3)for e := nums.Front(); e != nil; e = e.Next() {fmt.Println(e.Value)}}

包中有什么

包里只导出了两个类型和一个函数:

表示列表的List类型

表示列表元素的Element类型

创建List的函数container/list––––––––––––––container/list_// 表示双向列表type List struct{ ... }// 表示列表中的元素type Element struct{ ... }// 创建Listfunc New() *List

  

下面详细讲解该包的用法。

Element

先来看看Element类型:

container/list––––––––––––––container/list_type Element struct {Value interface{} // 存储在该元素中的值}

可以看到值的类型为 interface{},因此Element可以存储任何值。

创建List

使用New来创建List,函数原型如下:

container/list––––––––––––––container/list_func New() *List

示例:

oll := list.New()添加元素List导出了六个方法用于添加元素:container/list––––––––––––––container/list_// 追加新元素到末尾,返回该元素指针func (l *List) PushBack(v interface{}) *Element// 追加另一个列表到末尾func (l *List) PushBackList(other *List)// 添加新元素到开头,返回该元素指针func (l *List) PushFront(v interface{}) *Element// 添加另一个列表到开头func (l *List) PushFrontList(other *List)// 在mark后面插入新元素,返回新元素指针func (l *List) InsertAfter(v interface{}, mark *Element) *Element// 在mark前插入新元素,返回新元素指针func (l *List) InsertBefore(v interface{}, mark *Element) *Element

示例:

// 追加元素到末尾coll.PushBack(1)coll.PushBack("Gopher")// 添加元素到开头coll.PushFront("Cynhard")two := coll.PushFront(2)// 插入元素到two之前before2 := coll.InsertBefore("Before2", two)// 插入元素到two之后after2 := coll.InsertAfter("After2", two)coll2 := list.New()coll2.PushBack(3)coll2.PushFront("Tomcat")// 追加另外一个列表到末尾coll.PushBackList(coll2)// 添加另外一个列表到开头coll.PushFrontList(coll2)

应注意到一个列表中的元素的值的类型不必一致。

移动元素

List导出了四个方法用于移动元素:

container/list––––––––––––––container/list_// 移动e到mark之后func (l *List) MoveAfter(e, mark *Element)// 移动e到mark之前func (l *List) MoveBefore(e, mark *Element)// 移动e到末尾func (l *List) MoveToBack(e *Element)// 移动e到开头func (l *List) MoveToFront(e *Element)

注意e和mark都必须是l的内的元素,否则该函数不执行任何动作。

示例:

two := coll.PushFront(2)before2 := coll.InsertBefore("Before2", two)after2 := coll.InsertAfter("After2", two)// 将before2移动到two的后面coll.MoveAfter(before2, two)// 将after2移动到two的前面coll.MoveBefore(after2, two)// 将before2移动到开头coll.MoveToFront(before2)// 将after2移动到末尾coll.MoveToBack(after2)

访问元素

List导出了Back()和Front()返回结尾和开头元素:

container/list––––––––––––––container/list_// 返回结尾元素func (l *List) Back() *Element// 返回开头元素func (l *List) Front() *Element

示例:

fmt.Println(coll.Front().Value) // 打印开头元素的值fmt.Println(coll.Back().Value) // 打印结尾元素的值

 

遍历列表

Element导出了两个方法Prev()和Next()用以访问前一个或后一个元素:

container/list––––––––––––––container/list_// 返回下一个元素,如果没有下一个元素,返回nilfunc (e *Element) Next() *Element// 返回前一个元素,如果没有前一个元素,返回nilfunc (e *Element) Prev() *Element

示例:

// 顺序遍历for e := coll.Front(); e != nil; e = e.Next() {fmt.Print(e.Value, " ")}fmt.Println()// 逆序遍历for e := coll.Back(); e != nil; e = e.Prev() {fmt.Print(e.Value, " ")}fmt.Println()

获取列表长度

container/list––––––––––––––container/list_func (l *List) Len() int

示例:

mt.Println(coll.Len())移除元素container/list––––––––––––––container/list_// 移除e,返回e的值func (l *List) Remove(e *Element) interface{}// 清空列表func (l *List) Init() *List

示例:

coll := list.New()two := coll.PushFront(2)coll.Remove(two) // 移除twocoll.Init() // 清空列表

完整示例

package mainimport ("container/list""fmt")func printList(coll *list.List) {for e := coll.Front(); e != nil; e = e.Next() {fmt.Print(e.Value, " ")}fmt.Println()}func printListR(coll *list.List) {for e := coll.Back(); e != nil; e = e.Prev() {fmt.Print(e.Value, " ")}fmt.Println()}func main() {coll := list.New()coll.PushBack(1)coll.PushBack("Gopher")coll.PushFront("Cynhard")two := coll.PushFront(2)before2 := coll.InsertBefore("Before2", two)after2 := coll.InsertAfter("After2", two)coll.MoveAfter(before2, two)coll.MoveBefore(after2, two)coll.MoveToFront(before2)coll.MoveToBack(after2)coll2 := list.New()coll2.PushBack(3)coll2.PushFront("Tomcat")coll.PushBackList(coll2)coll.PushFrontList(coll2)printList(coll)printListR(coll)fmt.Println(coll.Front().Value)fmt.Println(coll.Back().Value)fmt.Println(coll.Len())coll.Remove(two)printList(coll)coll.Init()printList(coll)}

  

 

转载于:https://www.cnblogs.com/dfsxh/p/10318270.html

你可能感兴趣的文章
新形势下初创B2B行业网站如何经营
查看>>
初心大陆-----python宝典 第五章之列表
查看>>
sysbench使用笔记
查看>>
有关电子商务信息的介绍
查看>>
NFC·(近距离无线通讯技术)
查看>>
多线程基础(三)NSThread基础
查看>>
PHP的学习--Traits新特性
查看>>
ubuntu下,py2,py3共存,/usr/bin/python: No module named virtualenvwrapper错误解决方法
查看>>
Ext.form.field.Number numberfield
查看>>
Linux文件夹分析
查看>>
解决部分月份绩效无法显示的问题:timestamp\union al\autocommit等的用法
查看>>
nginx 域名跳转 Nginx跳转自动到带www域名规则配置、nginx多域名向主域名跳转
查看>>
man openstack >>1.txt
查看>>
linux几大服务器版本大比拼
查看>>
在BT5系统中安装postgresQL
查看>>
【Magedu】Week01
查看>>
写给MongoDB开发者的50条建议Tip25
查看>>
为什么要让带宽制约云计算发展
查看>>
2012-8-5
查看>>
VS中ProjectDir的值以及$(ProjectDir)../的含义
查看>>