前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Golang语言情怀-第52期 Go 语言标准库翻译 compress/list

Golang语言情怀-第52期 Go 语言标准库翻译 compress/list

作者头像
李海彬
发布2021-03-09 11:01:39
2550
发布2021-03-09 11:01:39
举报
文章被收录于专栏:Golang语言社区Golang语言社区

import "container/list"

list包实现了双向链表。要遍历一个链表:

代码语言:javascript
复制
for e := l.Front(); e != nil; e = e.Next() {
    // do something with e.Value
}
代码语言:javascript
复制
type Element
func (e *Element) Next() *Element
func (e *Element) Prev() *Element
type List
func New() *List
func (l *List) Init() *List
func (l *List) Len() int
func (l *List) Front() *Element
func (l *List) Back() *Element
func (l *List) PushFront(v interface{}) *Element
func (l *List) PushFrontList(other *List)
func (l *List) PushBack(v interface{}) *Element
func (l *List) PushBackList(other *List)
func (l *List) InsertBefore(v interface{}, mark *Element) *Element
func (l *List) InsertAfter(v interface{}, mark *Element) *Element
func (l *List) MoveToFront(e *Element)
func (l *List) MoveToBack(e *Element)
func (l *List) MoveBefore(e, mark *Element)
func (l *List) MoveAfter(e, mark *Element)
func (l *List) Remove(e *Element) interface{}

type Element

代码语言:javascript
复制
type Element struct {
    // 元素保管的值
    Value interface{}
    // 内含隐藏或非导出字段
}

Element类型代表是双向链表的一个元素。

func (*Element) Next
代码语言:javascript
复制
func (e *Element) Next() *Element

Next返回链表的后一个元素或者nil。

func (*Element) Prev
代码语言:javascript
复制
func (e *Element) Prev() *Element

Prev返回链表的前一个元素或者nil。

type List

代码语言:javascript
复制
type List struct {
    // 内含隐藏或非导出字段
}

List代表一个双向链表。List零值为一个空的、可用的链表。

func New
代码语言:javascript
复制
func New() *List

New创建一个链表。

func (*List) Init
代码语言:javascript
复制
func (l *List) Init() *List

Init清空链表。

func (*List) Len
代码语言:javascript
复制
func (l *List) Len() int

Len返回链表中元素的个数,复杂度O(1)。

func (*List) Front
代码语言:javascript
复制
func (l *List) Front() *Element

Front返回链表第一个元素或nil。

func (*List) Back
代码语言:javascript
复制
func (l *List) Back() *Element

Back返回链表最后一个元素或nil。

func (*List) PushFront
代码语言:javascript
复制
func (l *List) PushFront(v interface{}) *Element

PushBack将一个值为v的新元素插入链表的第一个位置,返回生成的新元素。

func (*List) PushFrontList
代码语言:javascript
复制
func (l *List) PushFrontList(other *List)

PushFrontList创建链表other的拷贝,并将拷贝的最后一个位置连接到链表l的第一个位置。

func (*List) PushBack
代码语言:javascript
复制
func (l *List) PushBack(v interface{}) *Element

PushBack将一个值为v的新元素插入链表的最后一个位置,返回生成的新元素。

func (*List) PushBackList
代码语言:javascript
复制
func (l *List) PushBackList(other *List)

PushBack创建链表other的拷贝,并将链表l的最后一个位置连接到拷贝的第一个位置。

func (*List) InsertBefore
代码语言:javascript
复制
func (l *List) InsertBefore(v interface{}, mark *Element) *Element

InsertBefore将一个值为v的新元素插入到mark前面,并返回生成的新元素。如果mark不是l的元素,l不会被修改。

func (*List) InsertAfter
代码语言:javascript
复制
func (l *List) InsertAfter(v interface{}, mark *Element) *Element

InsertAfter将一个值为v的新元素插入到mark后面,并返回新生成的元素。如果mark不是l的元素,l不会被修改。

func (*List) MoveToFront
代码语言:javascript
复制
func (l *List) MoveToFront(e *Element)

MoveToFront将元素e移动到链表的第一个位置,如果e不是l的元素,l不会被修改。

func (*List) MoveToBack
代码语言:javascript
复制
func (l *List) MoveToBack(e *Element)

MoveToBack将元素e移动到链表的最后一个位置,如果e不是l的元素,l不会被修改。

func (*List) MoveBefore
代码语言:javascript
复制
func (l *List) MoveBefore(e, mark *Element)

MoveBefore将元素e移动到mark的前面。如果e或mark不是l的元素,或者e==mark,l不会被修改。

func (*List) MoveAfter
代码语言:javascript
复制
func (l *List) MoveAfter(e, mark *Element)

MoveAfter将元素e移动到mark的后面。如果e或mark不是l的元素,或者e==mark,l不会被修改。

func (*List) Remove
代码语言:javascript
复制
func (l *List) Remove(e *Element) interface{}

Remove删除链表中的元素e,并返回e.Value。


参考资料:

Go语言中文文档

http://www.golang.ltd/

Go语言官方文档

https://golang.google.cn/

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2021-02-21,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 Golang语言情怀 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • type Element
    • func (*Element) Next
      • func (*Element) Prev
      • type List
        • func New
          • func (*List) Init
            • func (*List) Len
              • func (*List) Front
                • func (*List) Back
                  • func (*List) PushFront
                    • func (*List) PushFrontList
                      • func (*List) PushBack
                        • func (*List) PushBackList
                          • func (*List) InsertBefore
                            • func (*List) InsertAfter
                              • func (*List) MoveToFront
                                • func (*List) MoveToBack
                                  • func (*List) MoveBefore
                                    • func (*List) MoveAfter
                                      • func (*List) Remove
                                      领券
                                      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档