go语言如何对hashmap进行扩容
go语言如何对hashmap进行扩容?其实要解决这个问题也不难,为此小编总结了这篇文章,下面我们一起来看看对hashmap进行扩容的方法。
定义hashmap变量
由于go语言是一个强类型的语言,因此hashmap也是有类型的,具体体现在key和value都必须指定类型,比如声明一个key为string,value也是string的map,需要这样做
var m map[string]string // 声明一个hashmap,还不能直接使用,必须使用make来初始化m = make(map[string]string) // 初始化一个mapm = make(map[string]string, 3) // 初始化一个map并附带一个可选的初始bucket(非准确值,只是有提示意义)m := map[string]string{} // 声明并初始化m := make(map[string]string) // 使用make来初始化
get,set,delete
m := map[string]intm["a"] = 1fmt.Println(m["a"]) // 输出 1// 如果访问一个不存在的key,返回类型默认值fmt.Println(m["b"]) // 输出0// 测试key是否存在v, ok := m["b"]if ok { ...}// 删除一个keydelete(m, "a")迭代器// 只迭代keyfor k := range m { ...}// 同时迭代key-valuefor k, v := range m { ...}
在迭代的过程中是可以对map进行删除和更新操作的,规则如下:
迭代是无序的,跟插入是的顺序无关
迭代的过程中删除一个key,无论遍历还是没有遍历过都不会再遍历到
迭代的过程中添加一个key,不确定是否能遍历到
未初始化的map也可以迭代
其他
map的value是不可取地址的,意味着 &m["a"]这样的语法是非法的
len和cap分别可以获取当前map的kv个数和总容量
看完这篇文章,你们学会对hashmap进行扩容的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注亿速云行业资讯频道,感谢各位的阅读。
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。