7个月前 0 10 162
map是go语言内置的数据结构, 保存键值对的无序组合。
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)
}
版权声明:自由转载-非商用-非衍生-保持署名(创意共享3.0许可证)