GO语言容器大全(附样例代码)

在Go语言中,虽然没有像其他语言那样内置的复杂集合框架,但标准库提供的数据结构足以满足大部分常见需求。下面,我们将深入探讨切片(slice)、映射(map)和通道(channel)这三种基本容器,并通过代码示例来加深理解。

切片(Slice)

切片是Go语言中动态数组的实现,它提供了灵活且强大的功能来管理一组同类型的数据。切片是对数组的抽象,它提供了动态扩容的能力,使得我们可以根据需要动态地增加或减少元素的数量。

package main  import (  "fmt"  
)  func main() {  // 创建一个空的整数切片  var numbers []int  // 使用append函数向切片中追加元素  numbers = append(numbers, 1)  numbers = append(numbers, 2, 3)  numbers = append(numbers, 4, 5, 6)  // 打印切片内容  fmt.Println(numbers) // 输出: [1 2 3 4 5 6]  // 切片的切片操作  sliceOfSlice := numbers[1:4] // 创建一个从索引1到3(不包括4)的子切片  fmt.Println(sliceOfSlice)   // 输出: [2 3 4]  // 切片的扩容  numbers = append(numbers, 7, 8, 9, 10)  fmt.Println(numbers) // 输出可能类似于: [1 2 3 4 5 6 7 8 9 10]  // 切片的拷贝  copyOfNumbers := make([]int, len(numbers))  copy(copyOfNumbers, numbers)  fmt.Println(copyOfNumbers) // 输出与numbers相同  
}

在上面的代码中,我们展示了如何创建切片、向切片中添加元素、如何从切片中创建子切片、如何扩容切片,以及如何拷贝切片。

映射(Map)

映射是Go语言中的关联数组,用于存储键值对。映射的键必须是可比较的类型,而值可以是任意类型。

package main  import (  "fmt"  
)  func main() {  // 创建一个空的字符串到整数的映射  var ages map[string]int  // 初始化映射  ages = make(map[string]int)  // 向映射中添加键值对  ages["Alice"] = 25  ages["Bob"] = 30  ages["Charlie"] = 35  // 打印映射内容  fmt.Println(ages) // 输出类似于: map[Alice:25 Bob:30 Charlie:35]  // 从映射中获取值  aliceAge, exists := ages["Alice"]  if exists {  fmt.Printf("Alice's age is %d\n", aliceAge)  }  // 删除映射中的键值对  delete(ages, "Bob")  fmt.Println(ages) // Bob被删除了  // 遍历映射  for name, age := range ages {  fmt.Printf("%s is %d years old\n", name, age)  }  
}

在上面的代码中,我们展示了如何创建映射、向映射中添加键值对、从映射中获取值、删除映射中的键值对,以及如何遍历映射。

通道(Channel)

通道是Go语言中用于协程(goroutine)之间通信的一种机制。通道提供了一种安全的方式来传递数据,确保数据在发送和接收之间同步。

package main  import (  "fmt"  "time"  
)  func main() {  // 创建一个可以传递整数的通道  ch := make(chan int)  // 启动一个并发的goroutine来向通道发送数据  go func() {  time.Sleep(2 * time.Second) // 模拟耗时操作  ch <- 42                    // 向通道发送整数42  }()  // 从通道接收数据并打印  value := <-ch // 阻塞,直到接收到数据  fmt.Println(value) // 输出: 42  
}

在上面的代码中,我们展示了如何创建一个通道,并在一个并发的goroutine中向通道发送数据。主goroutine会阻塞在接收操作上,直到数据被发送到通道中。

列表(List)

Go语言的container/list包提供了一个双向链表实现。双向链表允许你在列表的任何位置高效地插入和删除元素。

package main  import (  "container/list"  "fmt"  
)  func main() {  // 创建一个新的双向链表  l := list.New()  // 在链表尾部添加元素  l.PushBack(1)  l.PushBack(2)  l.PushBack(3)  // 在链表头部添加元素  l.PushFront(0)  // 遍历链表并打印元素  for e := l.Front(); e != nil; e = e.Next() {  fmt.Println(e.Value)  }  
}

在这个例子中,我们创建了一个双向链表,并在其尾部和头部添加了元素。然后,我们遍历链表并打印出每个元素的值。

堆(Heap)

container/heap包提供了堆的实现,它允许你实现任意类型的堆,包括最小堆和最大堆。堆是一种特殊的树形数据结构,它满足父节点的值总是小于或等于(在最小堆中)或大于或等于(在最大堆中)其子节点的值。

package main  import (  "container/heap"  "fmt"  
)  // IntHeap 是一个由整数组成的最小堆  
type IntHeap []int  func (h IntHeap) Len() int           { return len(h) }  
func (h IntHeap) Less(i, j int) bool { return h[i] < h[j] }  
func (h IntHeap) Swap(i, j int)      { h[i], h[j] = h[j], h[i] }  func (h *IntHeap) Push(x interface{}) {  *h = append(*h, x.(int))  
}  func (h *IntHeap) Pop() interface{} {  old := *h  n := len(old)  x := old[n-1]  *h = old[0 : n-1]  return x  
}  func main() {  h := &IntHeap{2, 1, 5}  heap.Init(h)  heap.Push(h, 3)  fmt.Printf("minimum: %d\n", (*h)[0])  for h.Len() > 0 {  fmt.Printf("%d ", heap.Pop(h))  }  
}

在这个例子中,我们定义了一个IntHeap类型,它实现了heap.Interface接口所需的方法,从而使其可以作为一个最小堆来使用。我们初始化了一个堆,并向其中添加了一个元素。然后,我们打印出堆中的最小元素,并依次弹出并打印堆中的所有元素。

第三方容器库

除了标准库提供的数据结构之外,Go语言的开源社区也有许多优秀的第三方库,提供了更多种类的容器实现,如并发安全的队列、栈、环形缓冲区等。这些库通常提供了更高级的功能和更好的性能优化。

例如,一些流行的第三方容器库包括:

  • github.com/deckarep/golang-set:一个Go语言的集合库,提供了集合的基本操作。
  • github.com/goccy/go-graphviz:一个用于创建图形和可视化的库,虽然不是传统意义上的容器,但可以用于构建复杂的数据结构图。
  • github.com/workanator/go-floc:一个流式数据流处理库,提供了高级的数据流操作和并发处理功能。
总结

Go语言虽然没有内置的复杂集合框架,但通过其标准库和丰富的开源社区资源,开发者可以轻松地找到满足其需求的容器实现。无论是切片、映射、通道,还是列表、堆,甚至是更复杂的第三方容器库,Go语言都提供了灵活且高效的工具来管理数据。

希望这些详细的介绍和代码示例能帮助你更好地理解Go语言中的容器,并为你的Go编程之旅提供有力的支持!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/28508.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Mysql查询操作 联合查询 子查询

MySQL联合查询是指在一条SQL语句中使用UNION关键字将多个查询结果合并返回的操作。UNION查询能够将多条SELECT语句的结果合并成一个结果集&#xff0c;每个查询结果集的列数和列类型必须一致。 语法格式如下&#xff1a; SELECT 列1, 列2, 列3 FROM 表1 WHERE 条件1 UNION SE…

【归并排序】| 详解归并排序核心代码之合并两个有序数组 力扣88

&#x1f397;️ 主页&#xff1a;小夜时雨 &#x1f397;️专栏&#xff1a;动态规划 &#x1f397;️如何活着&#xff0c;是我找寻的方向 目录 1. 题目解析2. 代码 1. 题目解析 题目链接: https://leetcode.cn/problems/merge-sorted-array/description/ 本道题是归并排序的…

超拟人大模型:AI心理健康服务的未来

摘要&#xff1a; 周末听了一场聆心智能关于情感LLM的分享&#xff0c;总结了相关内容如下。在人工智能技术的浪潮中&#xff0c;超拟人大模型技术为心理健康服务领域带来了革命性的变化。本文将分析超拟人大模型的进展、CharacterGLM模型的特点、Emohaa模型的应用以及心理健康…

AI 挑战周杰伦?Suno 全新功能面世,即兴哼几句就能创作成歌,还能模仿声音!...

作者 | 王启隆 出品丨AI 科技大本营&#xff08;ID&#xff1a;rgznai100&#xff09; 2016 年&#xff0c;周杰伦根据女儿 Hathaway 在玩具钢琴上随意弹出的几个音符&#xff0c;激发出创作的灵感&#xff0c;谱写了一首温馨而深情的歌曲——《前世情人》。8 年过去&#xff0…

【每日随笔】摩托车控车 ① ( 油离配合 | 落脚油离配合 - 不给油 | 落脚油离配合 - 给油 | 正式油离配合 | 骑行姿态注意事项 )

文章目录 一、找 " 离合结合点 "二、落脚油离配合 ( 不给油 )1、该科目练习目的2、起步姿态3、开始练习 三、落脚油离配合 ( 给油 )1、练习目的2、熟悉油门转速3、练习步骤 四、正式油离配合1、练习目的2、练习步骤3、练习效果 五、骑行姿态注意事项1、基本骑行姿态2…

【Python高级编程】Matplotlib 绘图中文显示问题与常见错误合集

在 Matplotlib 中使用中文标题时出现错误可能是由于字体问题。Matplotlib 默认使用英文字体&#xff0c;不支持中文。要解决此问题&#xff0c;需要安装中文字体并将其设置为 Matplotlib 的默认字体。 安装中文字体 可以使用以下命令安装中文字体&#xff1a; sudo apt-get …

Cisco Packet Tracer实验(四)

生成树协议&#xff08;Spanning Tree Protocol&#xff09; 交换机在目的地址未知或接收到广播帧时是要进行广播的。如果交换机之间存在回路/环路&#xff0c;那么就会产生广播循环风暴&#xff0c;从而严重影响网络性能。 而交换机中运行的STP协议能避免交换机之间发生广播…

解决Qt的multimedia库在clion中依赖库补全的问题

解决Qt的multimedia库在clion中使用报错的问题 在clion中&#xff0c;使用Qt的multimedia库时会报如下错误&#xff1a; defaultServiceProvider::requestService(): no service found for - "org.qt-project.qt.mediaplayer" 我猜测出现这个错误的原因很可能是因为…

迅狐短视频矩阵管理系统核心功能

一、多平台管理&#xff1a;连接多个主流自媒体平台&#xff0c;满足多平台、多账号、多角色的协调需求 在现如今的多元化媒体环境中&#xff0c;一个优秀的内容创作者需要同时管理多个自媒体平台&#xff0c;并以不同的身份角色展现自己。迅狐短视频矩阵管理系统强大的多平台…

数据结构重要知识总结

数组 数组&#xff08;Array&#xff09; 是一种很常见的数据结构。它由相同类型的元素&#xff08;element&#xff09;组成&#xff0c;并且是使用一块连续的内存来存储。 我们直接可以利用元素的索引&#xff08;index&#xff09;可以计算出该元素对应的存储地址。 数组…

软设之系统设计之人机界面设计

人机界面设计原则: 1.置于用户控制之下 2.减少用户的记忆负担 3.保持界面的一致性 置于用户控制之下: 以不强迫用户进入不必要的或不希望的动作模式来定义交互方式 提供灵活的交互 允许用户交互可以被中断和撤销 当技能级别增加时可以使交互流水化并允许定制交互 使用…

如何充分利用 Postgres 的内存设置

为了充分利用 PostgreSQL 的内存设置&#xff0c;你需要调整多个参数以优化数据库性能。这些参数包括共享缓冲区&#xff08;shared_buffers&#xff09;、工作内存&#xff08;work_mem&#xff09;、维护工作内存&#xff08;maintenance_work_mem&#xff09;、有效缓存大小…

仅凭一图,即刻定位,AI图像定位技术

AI图像定位技术&#xff0c;解锁空间密码&#xff01;仅凭一图&#xff0c;即刻定位&#xff0c;精准至经纬度坐标&#xff0c;让世界无处不晓。 试试看能否猜中这张自拍照的背景所在&#xff1f;可别低估了A的眼力&#xff0c;答案说不定会让你大吃一惊呢。 近期&#xff0c;…

mysql主从备份

1&#xff0c;备份主库数据 2&#xff0c;配置主库 修改my.cnf文件&#xff0c;在[mysqld]加入下面的内容&#xff1a; # 服务的唯一编号 server-id1 # 开启mysql binlog功能 log-bin mysql-bin # 这个参数要加上&#xff0c;否则不会给更新的记录些到二进制文件里 lo…

第九站:Java黑——安全编码的坚固防线

在Java开发中&#xff0c;确保应用程序安全是一项至关重要的任务。以下是几个关于如何在Java中实施安全编码实践的例子&#xff0c;特别关注OWASP Top 10安全威胁中的几个关键点&#xff1a;加密解密、SQL注入防护。 1. 加密解密示例&#xff1a;使用Java Cryptography Archit…

现代CMake

文章目录 现代CMake-D选项&#xff1a;指定配置变量-G生成选项添加cpp源文件项目配置变量设置构建方式各种构建模式在编译器上的区别 project其他相关变量project初始化&#xff1a;LANGUAGES 字段project初始化&#xff1a;VERSION字段project 内的其他字段 设置C标准常见误区…

JWT令牌、过滤器Filter、拦截器Interceptor

目录 JWT令牌 简介 JWT生成 解析JWT 登陆后下发令牌 过滤器(Filter) Filter快速入门 Filter拦截路径 过滤器链 登录校验Filter-流程 拦截器(Interceptor) Interceptor 快速入门 拦截路径 登录校验流程 JWT令牌 简介 全称:JSON Web Token(https://iwt.io/) …

Oracle复习部分记录

GuassDB,Oracle,Postgresql 适用的hint说明 一、在使用with as 短语时&#xff0c;使用materialize 会生产临时表&#xff0c;执行完成后&#xff0c;PGA会将其清除。 materialize 二、pq_distribute 表示在并行过程中&#xff0c;按照并行对标划分多少个分区&#xff0c;a分…

0118__C语言——float.h文件

C语言——float.h文件_c float.h-CSDN博客