go语言如何对hashmap进行扩容

发布时间:2020-06-10 10:38:26 作者:Leah
来源:亿速云 阅读:328

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) // 初始化一个map
m = make(map[string]string, 3) // 初始化一个map并附带一个可选的初始bucket(非准确值,只是有提示意义)

m := map[string]string{} // 声明并初始化

m := make(map[string]string) // 使用make来初始化

get,set,delete

m := map[string]int
m["a"] = 1
fmt.Println(m["a"]) // 输出 1
// 如果访问一个不存在的key,返回类型默认值
fmt.Println(m["b"]) // 输出0
// 测试key是否存在
v, ok := m["b"]
if ok {
    ...
}
// 删除一个key
delete(m, "a")
迭代器
// 只迭代key
for k := range m {
    ...
}
// 同时迭代key-value
for k, v := range m {
    ...
}

在迭代的过程中是可以对map进行删除和更新操作的,规则如下:

迭代是无序的,跟插入是的顺序无关

迭代的过程中删除一个key,无论遍历还是没有遍历过都不会再遍历到

迭代的过程中添加一个key,不确定是否能遍历到

未初始化的map也可以迭代

其他

map的value是不可取地址的,意味着 &m["a"]这样的语法是非法的

len和cap分别可以获取当前map的kv个数和总容量

看完这篇文章,你们学会对hashmap进行扩容的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注亿速云行业资讯频道,感谢各位的阅读。

推荐阅读:
  1. 使用Go语言怎么对字典进行操作
  2. Java8 HashMap扩容算法实例解析

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

golang go语言 hashmap

上一篇:linux系统的配置文件的位置在哪

下一篇:怎么查看Linux内核和系统版本信息

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》