Go 集合Map · 2023年4月12日 0

《10节课学会Go-07-Map》

本文是全系列中第7 / 10篇:10节课学会Go

Map

map是Go语言中的一种内置数据结构,也称为哈希表或字典。它是一种无序的键值对集合,其中每个键唯一对应一个值,通过键来快速查找对应的值。在map中,所有的键都必须是同一类型,所有的值也必须是同一类型。

定义 Map与赋值

map的声明方式为:

var mapName map[keyType]valueType

其中,keyType表示键的类型,valueType表示值的类型。需要注意的是,这里声明的map变量并没有被初始化,如果直接使用将会引发运行时错误。正确的初始化方式是使用make函数:

mapName := make(map[keyType]valueType)

或者直接初始化:

mapName := map[keyType]valueType{
    key1: value1,
    key2: value2,
    ...
}

在map中添加或修改键值对可以直接使用下标运算符[],例如:

mapName[key] = value

如果键值对中的键已经存在,那么它所对应的值就会被更新;如果不存在,就会添加一个新的键值对。

查找map中的键值对也可以使用下标运算符[],例如:

value := mapName[key]

这个操作会返回键所对应的值,如果该键不存在,会返回该值类型的零值。

具体示例:

package main

import "fmt"

// Steps1 定义映射
func Steps1() {
  // Steps 1-1: map[T]X 表示定义了一个 Key 类型为 T,Value 类型为 X 的映射
  // 定义一个 int->int 的map
  var mpIntInt map[int]int // 零值map
  fmt.Printf("tmpIntInt:%+v len:%dn",
    mpIntInt,
    len(mpIntInt)) // len 可以获取当前 map 存储的映射数量
  // mpIntInt[1] =1 // nil 映射不能添加键,添加报错 panic: assignment to entry in nil map

  // Steps 1-2: 定义一个 int->string 的map并初始化
  mpIntString := map[int]string{1: "Golang", 2: "Tutorial"}
  fmt.Printf("tmpIntString:%+v len:%dn",
    mpIntString,
    len(mpIntString))

  // Steps 1-3: 用内建函数 make 来创建map
  mpIntBool := make(map[int]bool)
  fmt.Printf("tmpIntBool:%+v len:%dn",
    mpIntBool,
    len(mpIntBool))
  mpIntBool[0] = true
  fmt.Printf("tmpIntBool:%+v len:%dn",
    mpIntBool,
    len(mpIntBool))

  mpIntFloat32 := make(map[int]float32, 10)
  fmt.Printf("tmpIntFloat32:%+v len:%dn",
    mpIntFloat32,
    len(mpIntFloat32))

  mpStringSliceInt := make(map[string][]int, 10)
  fmt.Printf("tmpStringSliceInt:%+v len:%dn",
    mpStringSliceInt,
    len(mpStringSliceInt))
}

func main() {
  fmt.Println("Steps1():")
  Steps1()
}

map还有一些其他的特性:

  • delete(mapName, key):删除指定键的键值对。
  • len(mapName):返回map中键值对的数量。
  • for key, value := range mapName:遍历map中的键值对。

需要注意的是,由于map是无序的,所以遍历时不能保证顺序。

具体示例:

package main

import "fmt"

// Steps2 map的基础使用
func Steps2() {
  // Steps 2-1: 用内建函数 make 来创建map
  mpIntString := make(map[int]string)
  fmt.Printf("tmpIntString:%+v len:%dn",
    mpIntString,
    len(mpIntString))

  // Steps 2-2: 映射 mpIntString 中插入或修改元素
  mpIntString[0] = "Golang"
  mpIntString[1] = "World"
  mpIntString[1] = "Tutorial" // 修改mpIntString[1]元素
  mpIntString[2] = "Study"
  fmt.Printf("tmpIntString:%+v len:%dn",
    mpIntString,
    len(mpIntString))

  // Steps 2-3: 获取元素
  elem := mpIntString[0]
  fmt.Printf("telem:%+vn", elem)

  // Steps 2-4: 删除元素
  delete(mpIntString, 0)
  fmt.Printf("tmpIntString:%+v len:%dn",
    mpIntString,
    len(mpIntString))

  // Steps 2-5: 通过双赋值检测某个键是否存在
  // 若 key 在 mpIntString 中,ok 为 true ; 否则, ok 为 false
  elem, ok := mpIntString[0]
  fmt.Printf("telem:%+v ok:%tn", elem, ok)

  // Steps 2-6: 通过range遍历map
  fmt.Printf("tmpIntString:%+v len:%dn",
    mpIntString,
    len(mpIntString))
  for k, v := range mpIntString {
    fmt.Printf("tKey:%d, Value:%sn", k, v)
  }
}

func main() {
  fmt.Println("Steps2():")
  Steps2()
}

思考题

  1. 通过Map实现一个人员统计小程序
    1.1. 实现添加一个名字
    1.2. 实现查询一个名字是否存在
    1.3. 实现删除一个名字
    1.4. 实现更新一个名字
    1.5. 实现打印所有名字
    1.6. 实现统计总人数
  2. 通过map,struct,func实现求一个班级所有学生最高总分,最低总分,各学科最高,最低分,平均分,打印所有学生所有学科成绩
type Student struct {
  language float32
  math     float32
  english  float32
}

type class struct {
  mp map[string]Student
}

func (c class)ClassMaxScore() float64 {

  return 0
}

func (c class)ClassLanguageMaxScore() float64 {

  return 0
}

func (c class)PrintAllStudent()  {
  
}

func .....

参考

cnblogs.com/qcrao-2018/

jonny.website/posts/go-

draveness.me/golang/doc

 

本文是全系列中第7 / 10篇:10节课学会Go
打赏 赞(0) 分享'
分享到...
微信
支付宝
微信二维码图片

微信扫描二维码打赏

支付宝二维码图片

支付宝扫描二维码打赏

文章目录