Golang深入浅出之-掌握Go语言Map:初始化、增删查改与遍历

简介: 【4月更文挑战第21天】Go语言中的`map`提供快速的键值对操作,包括初始化、增删查改和遍历。初始化时,推荐使用`make()`函数,如`make(map[string]int)`。插入和查询键值对直接通过索引访问,更新则重新赋值。删除键值对需用`delete()`函数,确保键存在。遍历map常用`for range`,注意避免在遍历中修改map。了解这些并避免易错点,能提升代码效率和可读性。

Go语言中的map是一种非常实用的数据结构,它提供了基于键值对的快速查找、插入和删除功能。在实际编程中,熟练掌握map的初始化、增删查改操作以及遍历方法对于提升代码效率和可读性至关重要。本篇文章将深入浅出地探讨这些主题,同时揭示常见问题、易错点及相应的规避策略,并通过丰富的代码示例进行演示。
image.png

一、Map的初始化

基本初始化

创建一个空的map,可以使用make()函数:

package main

import "fmt"

func main() {
   
   
    // 初始化一个字符串到整数类型的map
    m := make(map[string]int)
    fmt.Println(m) // 输出:map[]
}

预填充初始化

如果希望在创建时就添加一些键值对,可以采用如下方式:

package main

import "fmt"

func main() {
   
   
    m := map[string]int{
   
   
        "apple":  1,
        "banana": 2,
        "orange": 3,
    }
    fmt.Println(m) // 输出:map[apple:1 banana:2 orange:3]
}

易错点:直接赋值空map m := map[string]int{},虽然语法正确,但不推荐,因为这样可能会引发编译器优化导致的未定义行为。建议始终使用make()函数初始化。

二、Map的增删查改操作

插入键值对

向map中插入数据,只需使用索引赋值的方式:

package main

import "fmt"

func main() {
   
   
    m := make(map[string]int)

    m["pear"] = 4
    fmt.Println(m) // 输出:map[pear:4]
}

查询键值

查询map中某个键对应的值,同样使用索引访问:

package main

import (
    "fmt"
    "log"
)

func main() {
   
   
    m := map[string]int{
   
   "cherry": 5}

    value, exists := m["cherry"]
    if exists {
   
   
        fmt.Println("Value:", value) // 输出:Value: 5
    } else {
   
   
        log.Println("Key not found")
    }
}

更新键值

更新map中已存在的键的值,与插入操作类似,直接对键进行赋值即可:

package main

import "fmt"

func main() {
   
   
    m := map[string]int{
   
   "grape": 6}

    m["grape"] = 7
    fmt.Println(m) // 输出:map[grape:7]
}

删除键值对

使用delete()函数删除指定键的键值对:

package main

import "fmt"

func main() {
   
   
    m := map[string]int{
   
   "kiwi": 8}

    delete(m, "kiwi")
    fmt.Println(m) // 输出:map[]
}

易错点:在未检查键是否存在的情况下直接删除,可能导致运行时错误。务必确保键存在于map中再进行删除操作。

三、Map的遍历

Go语言提供了两种方式遍历map:

使用for range

这是最常见的遍历方式,可以同时获取键和值:

package main

import "fmt"

func main() {
   
   
    fruits := map[string]int{
   
   "pineapple": 9, "watermelon": 10}

    for key, value := range fruits {
   
   
        fmt.Printf("Key: %s, Value: %d\n", key, value)
    }
    // 输出:
    // Key: pineapple, Value: 9
    // Key: watermelon, Value: 10
}

只遍历键或值

有时仅需遍历键或值,可以忽略不需要的部分:

package main

import "fmt"

func main() {
   
   
    fruits := map[string]int{
   
   "peach": 11, "plum": 12}

    // 只遍历键
    for key := range fruits {
   
   
        fmt.Println("Key:", key)
    }

    // 只遍历值
    for _, value := range fruits {
   
   
        fmt.Println("Value:", value)
    }
}

易错点:在遍历过程中修改map可能会导致未定义的行为。若需要在遍历过程中修改map,应先复制map或使用临时变量存储待修改的键值对。

总结,熟练掌握Go语言map的初始化、增删查改操作以及遍历方法,有助于编写高效、清晰的代码。注意避免文中提到的易错点,如直接赋值空map、未检查键存在性进行删除操作、遍历过程中修改map等,将使你的程序更加健壮。通过实践上述代码示例,相信你对Go语言map的理解和应用将更上一层楼。

目录
相关文章
|
5月前
|
存储 JavaScript Java
(Python基础)新时代语言!一起学习Python吧!(四):dict字典和set类型;切片类型、列表生成式;map和reduce迭代器;filter过滤函数、sorted排序函数;lambda函数
dict字典 Python内置了字典:dict的支持,dict全称dictionary,在其他语言中也称为map,使用键-值(key-value)存储,具有极快的查找速度。 我们可以通过声明JS对象一样的方式声明dict
390 2
|
5月前
|
Java 编译器 Go
【Golang】(1)Go的运行流程步骤与包的概念
初次上手Go语言!先来了解它的运行流程吧! 在Go中对包的概念又有怎样不同的见解呢?
314 4
|
5月前
|
Java 编译器 Go
【Golang】(5)Go基础的进阶知识!带你认识迭代器与类型以及声明并使用接口与泛型!
好烦好烦好烦!你是否还在为弄不懂Go中的泛型和接口而烦恼?是否还在苦恼思考迭代器的运行方式和意义?本篇文章将带你了解Go的接口与泛型,还有迭代器的使用,附送类型断言的解释
289 3
|
5月前
|
存储 安全 Java
【Golang】(4)Go里面的指针如何?函数与方法怎么不一样?带你了解Go不同于其他高级语言的语法
结构体可以存储一组不同类型的数据,是一种符合类型。Go抛弃了类与继承,同时也抛弃了构造方法,刻意弱化了面向对象的功能,Go并非是一个传统OOP的语言,但是Go依旧有着OOP的影子,通过结构体和方法也可以模拟出一个类。
324 2
|
5月前
|
存储 Java Go
【Golang】(3)条件判断与循环?切片和数组的关系?映射表与Map?三组关系傻傻分不清?本文带你了解基本的复杂类型与执行判断语句
在Go中,条件控制语句总共有三种if、switch、select。循环只有for,不过for可以充当while使用。如果想要了解这些知识点,初学者进入文章中来感受吧!
236 3
|
8月前
|
存储 人工智能 安全
深入理解 go sync.Map - 基本原理
本文介绍了 Go 语言中 `map` 在并发使用时的常见问题及其解决方案,重点对比了 `sync.Mutex`、`sync.RWMutex` 和 `sync.Map` 的性能差异及适用场景。文章指出,普通 `map` 不支持并发读写,容易引发错误;而 `sync.Map` 通过原子操作和优化设计,在某些场景下能显著提升性能。同时详细讲解了 `sync.Map` 的基本用法及其适合的应用环境,如读多写少或不同 goroutine 操作不同键的场景。
390 1
|
8月前
|
人工智能 测试技术 持续交付
Golang深入浅出之-Go语言中的持续集成与持续部署(CI/CD)
持续集成与持续部署(CI/CD)是现代软件开发的关键实践,尤其适用于Go语言项目。本文探讨了Go项目中常见的CI/CD问题,如测试覆盖不足、版本不一致和构建时间过长,并提供解决方案及GitHub Actions示例代码,帮助开发者优化流程,提升交付效率和质量。
270 5
|
10月前
|
存储 安全 Go
Map的遍历与判断键是否存在-《Go语言实战指南》
本文介绍了 Go 语言中对 `map` 的常见操作,包括遍历所有项和判断键是否存在。通过 `for range` 可以遍历 `map` 的键值对、仅键或仅值(需忽略键)。注意,`map` 遍历顺序是随机的。判断键是否存在时,使用双赋值语法 `value, ok := map[key]`,其中 `ok` 表示键是否存在。直接访问不存在的键会返回类型的零值,可能导致逻辑错误。掌握这些机制可更安全高效地处理键值对数据。
|
存储 缓存 安全
Go 语言中的 Sync.Map 详解:并发安全的 Map 实现
`sync.Map` 是 Go 语言中用于并发安全操作的 Map 实现,适用于读多写少的场景。它通过两个底层 Map(`read` 和 `dirty`)实现读写分离,提供高效的读性能。主要方法包括 `Store`、`Load`、`Delete` 等。在大量写入时性能可能下降,需谨慎选择使用场景。
初始化Map大小并非用多少指定多少
初始化Map大小并非用多少指定多少

推荐镜像

更多