Go语言中三种容器类型的数据结构详解

 更新时间:2025年02月14日 09:29:41   作者:我是区块链小学生  
在 Go 语言中,有三种主要的容器类型用于存储和操作集合数据这篇文章主要为大家介绍了三者的使用与区别,感兴趣的小伙伴可以跟随小编一起学习一下

基本概念

在 Go 语言中,有三种主要的容器类型用于存储和操作集合数据:数组(Array)切片(Slice)映射(Map)。以下是它们的详细说明和对比:

1. 数组(Array)

定义
数组是具有 固定长度 的容器,存储相同类型的元素。长度在声明时确定,不可变。

特点

  • 值类型:赋值或传参时会复制整个数组。
  • 内存连续分配,访问速度快。

声明与初始化

// 声明长度为3的整型数组,默认初始化为零值
var arr1 [3]int

// 声明并初始化
arr2 := [3]int{1, 2, 3}

// 自动推断长度
arr3 := [...]int{4, 5, 6}

使用场景

适合需要固定大小且对内存敏感的场合(如底层算法优化),但日常开发中较少直接使用。

2. 切片(Slice)

定义

切片是基于数组的 动态长度 抽象,提供更灵活的容器。切片本身是引用类型,底层指向一个数组。

特点

  • 动态扩容:长度可动态增长(通过 append 函数)。
  • 引用语义:赋值或传参时传递指针,多个切片可能共享底层数组。

声明与初始化

// 直接声明切片(nil切片)
var s1 []int

// 通过数组创建切片
arr := [5]int{1, 2, 3, 4, 5}
s2 := arr[1:3] // 包含元素 [2, 3]

// 使用 make 创建切片
s3 := make([]int, 3, 5) // 长度3,容量5

// 直接初始化
s4 := []int{1, 2, 3}

常用操作

s := []int{1, 2}
s = append(s, 3)      // 追加元素 → [1, 2, 3]
sub := s[1:]          // 截取子切片 → [2, 3]

使用场景

绝大多数集合操作的默认选择(如动态列表、数据流处理)。

3. 映射(Map)

定义

映射是 键值对(Key-Value) 的无序集合,通过哈希表实现,键必须可哈希(如 intstring)。

特点

  • 动态扩容:自动增长以容纳更多键值对。
  • 引用语义:赋值或传参时传递指针。
  • 键唯一,值可重复。

声明与初始化

// 声明一个映射(nil映射,不可直接使用)
var m1 map[string]int

// 使用 make 初始化
m2 := make(map[string]int)

// 直接初始化
m3 := map[string]int{
    "Alice": 25,
    "Bob":   30,
}

常用操作

m := map[string]int{}
m["Charlie"] = 28    // 添加或修改键值对
age, ok := m["Bob"]  // 检查键是否存在(ok为bool)
delete(m, "Alice")   // 删除键

使用场景

快速查找、去重计数、配置管理等需要键值关联的场景。

对比总结

特性数组(Array)切片(Slice)映射(Map)
长度固定动态可变动态可变
类型语义值类型(复制整个数据)引用类型(共享底层数组)引用类型(共享存储)
内存分配编译时确定运行时动态分配运行时动态分配
访问方式索引(0-based)索引(0-based)键(Key)
主要用途固定大小数据块动态集合操作键值对关联存储

注意事项

切片共享底层数组

多个切片可能共享同一底层数组,修改一个切片可能影响其他切片。

arr := [3]int{1, 2, 3}
s1 := arr[:]  // s1 = [1,2,3]
s2 := s1[1:]  // s2 = [2,3]
s2[0] = 100   // s1变为 [1,100,3]

映射的无序性

遍历映射时,键值对的顺序不固定(Go 1.12+ 在扩容时随机化遍历顺序)。

并发安全

切片和映射在并发读写时需加锁(或使用 sync.Map)。

到此这篇关于Go语言中三种容器类型的数据结构详解的文章就介绍到这了,更多相关Go数据结构内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • golang中struct和interface的基础使用教程

    golang中struct和interface的基础使用教程

    Go不同于一般的面向对象语言,需要我们好好的学习研究,下面这篇文章主要给大家介绍了关于golang中struct和interface的基础使用的相关资料,需要的朋友可以参考借鉴,下面随着小编来一起学习学习吧。
    2018-03-03
  • 如何组织Go代码目录结构依赖注入wire使用解析

    如何组织Go代码目录结构依赖注入wire使用解析

    这篇文章主要为大家介绍了如何组织Go代码目录结构依赖注入wire使用解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-07-07
  • Go语言中关闭带缓冲区的频道实例分析

    Go语言中关闭带缓冲区的频道实例分析

    这篇文章主要介绍了Go语言中关闭带缓冲区的频道,实例分析了带缓冲区频道的原理与用法,以及关闭带缓冲区频道的技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-02-02
  • GO中sync包自由控制并发示例详解

    GO中sync包自由控制并发示例详解

    这篇文章主要为大家介绍了GO中sync包自由控制并发示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-08-08
  • golang中的并发和并行

    golang中的并发和并行

    这篇文章主要介绍了golang中的并发和并行用法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-05-05
  • Go切片导致rand.Shuffle产生重复数据的原因与解决方案

    Go切片导致rand.Shuffle产生重复数据的原因与解决方案

    在 Go 语言的实际开发中,切片(slice)是一种非常灵活的数据结构,然而,由于其底层数据共享的特性,在某些情况下可能会导致意想不到的 Bug,本文将详细分析 rand.Shuffle 之后,切片中的数据出现重复的问题,探讨其根本原因,并给出最佳解决方案,需要的朋友可以参考下
    2025-02-02
  • Golang开发Go依赖管理工具dep安装验证实现过程

    Golang开发Go依赖管理工具dep安装验证实现过程

    这篇文章主要为大家介绍了Golang开发Go依赖管理工具dep安装验证及初始化一系列实现过程,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步
    2021-11-11
  • Golang正整数指定规则排序算法问题分析

    Golang正整数指定规则排序算法问题分析

    这篇文章主要介绍了Golang正整数指定规则排序算法问题,结合实例形式分析了Go语言排序算法操作技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2017-01-01
  • go:gin输出日志文件方式

    go:gin输出日志文件方式

    这篇文章主要介绍了go:gin输出日志文件方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-01-01
  • 详解如何通过Go来操作Redis实现简单的读写操作

    详解如何通过Go来操作Redis实现简单的读写操作

    作为最常用的分布式缓存中间件——Redis,了解运作原理和如何使用是十分有必要的,今天来学习如何通过Go来操作Redis实现基本的读写操作,需要的朋友可以参考下
    2023-09-09

最新评论