首页 > 后端开发 > Golang > 正文

Golang containerList链表操作实践

P粉602998670
发布: 2025-10-03 10:40:02
原创
882人浏览过
答案:container/list是Go标准库的双向链表,通过PushFront/PushBack添加元素,Front遍历,findInList查找需类型断言,Remove删除,InsertAfter/Before插入,Element操作核心,Value为interface{},并发不安全。

golang containerlist链表操作实践

在 Go 语言中,container/list标准库提供的双向链表实现,适用于需要频繁插入和删除元素的场景。它不是泛型链表(直到 Go 1.18 才支持泛型),但借助 interface{} 可以存储任意类型的数据。下面通过实际用法带你掌握 container/list 的核心操作。

初始化链表与添加元素

使用 list.New() 创建一个空的双向链表,也可以直接声明 var l list.List。添加元素常用的方法有 PushFront 和 PushBack。

示例:

package main

import (
    "container/list"
    "fmt"
)

func main() {
    l := list.New()
    l.PushBack("first")
    l.PushFront("before first")
    l.PushBack(123)
    l.PushBack(true)

    for e := l.Front(); e != nil; e = e.Next() {
        fmt.Println(e.Value)
    }
}
登录后复制

输出结果会是:

立即学习go语言免费学习笔记(深入)”;

before first
first
123
true
登录后复制

说明 Front 插入在头部,Back 插入在尾部。

遍历与查找元素

链表不支持下标访问,必须通过指针逐个遍历。每个元素是 *list.Element 类型,其 Value 字段保存实际值。

若要查找特定值,需手动遍历比较:

BetterYeah AI
BetterYeah AI

基于企业知识库构建、训练AI Agent的智能体应用开发平台,赋能客服、营销、销售场景 -BetterYeah

BetterYeah AI 110
查看详情 BetterYeah AI
func findInList(l *list.List, target string) *list.Element {
    for e := l.Front(); e != nil; e = e.Next() {
        if val, ok := e.Value.(string); ok && val == target {
            return e
        }
    }
    return nil
}
登录后复制

注意:Value 是 interface{},取值时要做类型断言。

删除与修改元素

可以通过 Element 指针直接删除某个节点,调用 Remove 方法。

示例:删除值为 "first" 的节点

elem := findInList(l, "first")
if elem != nil {
    l.Remove(elem)
    fmt.Println("Removed 'first'")
}
登录后复制

修改值也很简单,直接赋值即可:

if elem := findInList(l, "before first"); elem != nil {
    elem.Value = "new head"
}
登录后复制

在指定位置插入新元素

除了首尾插入,还可以在某个元素前后插入:

target := findInList(l, "new head")
if target != nil {
    l.InsertAfter("after head", target)
    l.InsertBefore("before head", target)
}
登录后复制

InsertAfter 和 InsertBefore 接收两个参数:插入的值和目标 element。

基本上就这些。container/list 虽然不如 slice 使用广泛,但在需要高效中间插入删除的场景非常实用。关键是理解 Element 的作用,以及如何通过它操作链表结构。注意并发不安全,多协程访问时要加锁。不复杂但容易忽略细节,比如类型断言和空指针判断。用熟了很顺手。

以上就是Golang containerList链表操作实践的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号