Go语言双向链表list.List的实现示例

 更新时间:2025年09月18日 08:22:37   作者:liushen0528  
Go语言中的list.List是包提供的双向链表实现,具有高效的插入和删除操作能力,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

Go语言中的list.Listcontainer/list包提供的双向链表实现,具有高效的插入和删除操作能力。

一、list.List数据结构特性

list.List数据结构定义源码如下:

// List represents a doubly linked list.
// The zero value for List is an empty list ready to use.
type List struct {
	root Element // sentinel list element, only &root, root.prev, and root.next are used
	len  int     // current list length excluding (this) sentinel element
}

// Element is an element of a linked list.
type Element struct {
	// Next and previous pointers in the doubly-linked list of elements.
	// To simplify the implementation, internally a list l is implemented
	// as a ring, such that &l.root is both the next element of the last
	// list element (l.Back()) and the previous element of the first list
	// element (l.Front()).
	next, prev *Element

	// The list to which this element belongs.
	list *List

	// The value stored with this element.
	Value any
}

特性如下:

1)双链表结构:每个节点(Element类型)包含Prev和Next指针,分别指向其前驱和后继节点,形成双向链接。

2)类型灵活性:节点值采用interface{}类型,可存储任意数据,但需注意类型断言可能引发的运行时错误。

3)环状设计:通过内置的哨兵节点(root)形成环状结构,有效简化边界条件的处理逻辑。

二、list.List基本操作

1)list.List初始化

list.List初始化有两种方式:通过new方法创建和生命初始化,代码示例如下:

// 通过new方法初始化
lt1 := list.New()

// 通过声明初始化
var lt2 list.List

2)list.List插入操作

lsit.List支持从链表的头部或者尾部插入数据,也支持在指定元素的前后插入数据。代码示例如下:

func main() {

    lt1 := list.New()

    // 链表尾部插入数据
    lt1.PushBack("back")

    // 链表头部插入数据
    lt1.PushFront("front")

    // 在链表尾部元素之前插入数据
    lt1.InsertBefore("before", lt1.Back())
    
    // 在链表尾部元素之后插入数据
    lt1.InsertAfter("after", lt1.Back())
}

3)list.List删除操作

list.List支持删除元素,代码示例如下:

// 删除元素
lt1.Remove(lt1.Front())

4)list.List移动操作

list.List支持移动操作,可以将某个元素移动到链表头部或者尾部,也可以将某个元素移动到指定元素的前后,代码示例如下:

// 将元素移动到头部
lt1.MoveToFront(lt1.Back())

// 将元素移动到尾部
lt1.MoveToBack(lt1.Front())

// 将元素移动到指定元素之前
e1 := lt1.PushBack("e1")
lt1.MoveBefore(e1, lt1.Back())

// 将元素移动到指定元素之前
e2 := lt1.PushBack("e2")
lt1.MoveAfter(e2, lt1.Front())

5)list.List访问操作

list.List支持两种访问操作:首尾访问和遍历访问。

首位访问通过list.List提供的Front()和Back()方法访问,代码示例如下:

// 从头部访问元素
e3 := lt1.Front()

// 从尾部访问元素
e4 := lt1.Back()

遍历访问通过Next()和Prev()方法实现,代码示例如下:

// 从头部向尾部开始遍历
for e := lt1.Front(); e != nil; e = e.Next() {
    fmt.Print(e.Value, " ")
}

// 从尾部向头部部开始遍历
for e := lt1.Back(); e != nil; e = e.Prev() {
    fmt.Print(e.Value, " ")
}

6)list.List链表合并操作

list.List支持两个链表合并,可以将一个链表合并到另一个链表的头部或者尾部,代码示例如下:

lt2 := list.New()
lt2.PushBack("11")

lt3 := list.New()
lt3.PushBack("33")

lt4 := list.New()
lt4.PushBack("44")

// 将链表合并到头部
lt2.PushFrontList(lt3)

// 将链表合并到尾部
lt2.PushBackList(lt4)

到此这篇关于Go语言双向链表list.List的实现示例的文章就介绍到这了,更多相关Go语言双向链表list.List内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:

相关文章

  • go micro微服务框架项目搭建方法

    go micro微服务框架项目搭建方法

    这篇文章主要为大家介绍了go micro微服务框架项目搭建方法详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-01-01
  • 详解golang中的method

    详解golang中的method

    这篇文章主要介绍了golang中的method的相关资料,帮助大家更好的理解和使用golang,感兴趣的朋友可以了解下
    2021-01-01
  • Go Java算法之二叉树的所有路径示例详解

    Go Java算法之二叉树的所有路径示例详解

    这篇文章主要为大家介绍了Go Java算法之二叉树的所有路径示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-08-08
  • SpringEvent优雅解耦时连续两个bug的解决方案

    SpringEvent优雅解耦时连续两个bug的解决方案

    这篇文章主要为大家介绍了SpringEvent优雅解耦时连续两个bug的解决方法,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-12-12
  • Golang websocket协议使用浅析

    Golang websocket协议使用浅析

    这篇文章主要介绍了Golang websocket协议的使用,WebSocket是一种新型的网络通信协议,可以在Web应用程序中实现双向通信,感兴趣想要详细了解可以参考下文
    2023-05-05
  • go编译so库让python引用编译后没有.h文件的问题

    go编译so库让python引用编译后没有.h文件的问题

    有时python需要引用go的一些开源库,这时就需要go编译成python可调用的库,本文给大家介绍了go编译so库让python引用,编译后没有.h文件的问题,需要的朋友可以参考下
    2024-02-02
  • Golang sync.Pool的源码解析

    Golang sync.Pool的源码解析

    Pool是用于存放临时对象的集合,这些对象是为了后续的使用,以达到复用对象的效果,本文将详解解析sync.Pool 源码,需要的朋友可以参考下
    2023-05-05
  • Golang如何实现任意进制转换的方法示例

    Golang如何实现任意进制转换的方法示例

    进制转换是人们利用符号来计数的方法,进制转换由一组数码符号和两个基本因素“基数”与“位权”构成,这篇文章主要给大家介绍了关于Golang如何实现10进制转换62进制的方法,文中给出了详细的示例代码供大家参考学习学习,下面随着小编来一起学习学习吧。
    2017-09-09
  • Go如何优雅的关闭goroutine协程

    Go如何优雅的关闭goroutine协程

    本文将介绍首先为什么需要主动关闭goroutine,并介绍如何在Go语言中关闭goroutine的常见套路,包括传递终止信号和协程内部捕捉终止信号,之后,文章列举了需要主动关闭协程运行的常见场景,希望通过本文的介绍,读者能够掌握如何在适当的时候关闭goroutine
    2023-05-05
  • 使用Go创建一个TCP服务器的操作步骤

    使用Go创建一个TCP服务器的操作步骤

    在网络编程中,TCP 是最常见的传输协议之一,Go 提供了 net 包,可以方便地实现 TCP 服务器与客户端通信,本篇将以实战形式演示如何用 Go 创建一个 TCP 服务器,并让多个客户端与之通信,需要的朋友可以参考下
    2025-08-08

最新评论