map
Posted zbhbc
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了map相关的知识,希望对你有一定的参考价值。
map是一个拥有键值对元素的无序集合。
在Go语言中,map是散列表的引用。map[K]V所有的键都有相同的数据类型,同时所有的值也有相同的数据类型。
键K,必须是可以通过操作符==来进行比较的数据类型,所以map可以检测某一键是否已经存在。
使用make创建map:
myMap := make(map[K]V)
使用map的字面量来新建一个带初始化键值对的字典
myMap := map[string]int64{
"a": 1
"b": 2
}
新的空map表达式:map[K]V{}
移除一个元素delete(map, K)函数,即使键不在map中也是安全的。
map元素不是一个变量,无法获取地址。
迭代map,map中元素的迭代顺序是不一定的:
for k, v := range ages {
fmt.Println(k, v)
}
排序:
names := make([]string, 0, len(myMap))
for k := range myMap {
names = append(names, k)
}
sort.Strings(names)
for _, v := range names {
fmt.Println(v, myMap[v])
}
map的零值是nil,空的map不是nil。
判断map是否有该键:
if v, ok := myMap[K]; !ok {...}
可以把map[string]bool形式当做集合使用
以上是关于map的主要内容,如果未能解决你的问题,请参考以下文章