本系列前面的文章:
map是一种映射,可以将键(key
)映射到值(value
),格式为:map[keyType]valueType
。
声明一个map并初始化它,使用key:value
进行初始化:
var scores = map[string]int {"数学":100, "语文":90, "Go":100}
如果不想直接初始化,可以先声明再使用,注意这样需要使用make
函数初始化后才能使用:
var scores map[string]int
scores = make(map[string]int)
为什么这样声明需要使用make
函数?
map
的零值是nil map
,没有键,也不能添加键。
var m map[string]int //声明一个m map,它现在默认是nil
fmt.Println(m) //map[]
m["A"] = 1 //报错:assignment to entry in nil map
所以为了不让该map
不是nil
,需要使用make
初始化:
var m map[string]int //nil
m = make(map[string]int) //初始化
m["A"] = 1 //添加元素
fmt.Println(m) //map[A:1]
当然,方便的短变量声明方式也能用:
m := map[string]int {"A":1, "B":2}
或者
m := make(map[string]int)
m["A"] = 1
m["B"] = 2
(增)增加键值对:
scores["数学"] = 100 //向scores这个map添加了键为“数学”,值为100的数据
scores["语文"] = 90
(删)删除键值对:
delete(scores, "语文")
(改)修改键值对和增加键值对的语法相同(当key
不存在时为增加,当key
存在时为修改):
scores["语文"] = 10
(查)使用key
可以查找到对应的value
,会返回两个值,第一个是key
对应的value
,第二个是布尔值(如果key
存在,是true
;否则是false
)。如果查找的key
不存在,则会返回value
类型的“零值”:
score, exist := scores["数学"] //使用两个返回值
fmt.Println(score, exist) //100 true
score1 := scores["语文"] //使用一个返回值
fmt.Println(score1) //90
score2, exist2 := scores["Java"] //查找不存在的key
fmt.Println(score2, exist2) //0 false
和slice
一样,map
也是引用类型,则意味着,如果有几个map
同时指向一个底层map
,其中一个map
改变某个键值对,那么其他的也会做出同样的改变(因为底层map
变了)。
package main
import "fmt"
func main() {
map0 := make(map[string]string) //底层map0
map0["name"] = "XingXiaoguan" //增加一个键值对
//map1 map2 引用map0
map1 := map0
map2 := map0
fmt.Println(map0["name"], map1["name"], map2["name"]) //都是XingXiaoguan
map1["name"] = "XingRenGuanXue" //改变map1的name对应的值
fmt.Println(map0["name"], map1["name"], map2["name"]) //全部变为XingRenGuanXue
}
使用len
函数可以获取map
中key
的数量:
keyNum := len(scores) //获取scores这个map中key的数量
map
是无序的,所以其返回的元素顺序可能每次都不同。
可以使用range
关键字遍历map
,这里range
返回的第一个值是key
,第二个值是value
:
//遍历scores map
for key, value := range scores {
fmt.Println(key, value)
}
输出:
数学 100
语文 90
如有错误,还请指正。
点击这里认识我 。 (^o^)/
原文:https://www.cnblogs.com/xingrenguanxue/p/13443372.html