go 之 map 类型

Map

map是go语言内置的数据结构, 保存键值对的无序组合。

特征

  1. 它的容量只受到机器内存的限制
  2. 里面的所有键都是唯一的而且必须支持==!=等操作符的类型
  3. 大部分go的数据类型都可用作Map的键,例如int, string, float, rune, 指针类型, 结构体都是可以的

Map和切片是一样的, 都属于引用类型, 所以不管Map的多大, 它的传递始终是廉价的,Map的查询非常快, 但是比切片和数组直接索引查询要慢大概两个数量级。

创建Map

make(map[keyType]valueType, capacity)
make(map[keyType]valueType)
map[keyType]valueType{}
map[keyType]valueType{key:value, .....}

第一种:可以预申请一定空间, 但是超过空间, Map会自动扩容
第二种和第三种效果一样
第四种:可以初始化一些值

age := make(map[string]int, 5)
age["jack"] = 12
age["lily"] = 32
fmt.Println(age)
fmt.Println(len(age))

map[jack:12 lily:32]
2

映射查询

if value, found := age["jack"]; found {
      fmt.Println("jack's age is", value)
} else {
        fmt.Println("key not found")
}

第一个参数是Map对应键的返回值, 第二个参数是返回布尔值, 如果found为true的话说明map有对应的键。

更新映射

age["jack"] = 45 // 更新
fmt.Println(age)
age["tom"] = 78 //添加
fmt.Println(age)
delete(age, "lily") //删除
fmt.Println(age)

遍历

for key, value := range age {
    fmt.Println(key, "=>", value)
}
本作品采用《CC 协议》,转载必须注明作者和本文链接
讨论数量: 0
(= ̄ω ̄=)··· 暂无内容!

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!