1人参与 • 2025-02-14 • Golang
本篇博客将会介绍go语言当中的另一大核心数据类型——map(映射),当然在介绍这个数据类型之前我们还是要思考引入这个数据类型的原因:
❓ 需求:要求完成对一个班级所有同学的信息管理(包括但不限于增删改查),主要字段有名字,编号并且能够根据编号快速修改对应同学的信息
在我们学习map之前,我们唯一学过的收集器类型就是数组与切片,那么可以通过下面的代码完成上述功能:
// 定义学生姓名
var stunamearr = []string{"zhangsan", "lisi", "wangwu"}
var stuidarr = []string{"1001", "1002", "1003"}
// 修改编号为1001的同学姓名为zhangyi
var targetindex = -1
for index, id := range stuidarr {
if id == "1001" {
targetindex = index
break
}
}
stunamearr[targetindex] = "zhangyi"
fmt.println(stunamearr)
从上述代码我们可以看出,我们只能通过两个切片分别存储学生的姓名和编号,当需要修改某个特定学生的信息时,我们还需要查找出目标学生的存储下标,并根据该下标修改其余切片的信息。
📖 缺点:上述代码归根到底没有做到对学生信息的统一管理,并且实际上学生的编号与姓名之间应该存在着某种对应关系,不应该依赖于下标进行间接关联,而是应该存在直接关联关系!于是引入了我们的映射类型——map
map:go语言当中的map是一种**key(键)-value(值)**结构的数据类型,可以通过key快速定位到value值,事实上很多编程语言都有对应的key-value结构,比如python当中的字典、javascript当中的object
📖 数组与映射的区别:
数组是连续存储的,但是map其底层实现决定了它是随机存储的
数组可以通过下标index访问某个元素值,但是map当中只能通过key访问对应的value元素值
map是一个引用类型,其声明语法如下:
var map_name map[key_type]value_type
其中:
初始化方式1:先声明后赋值
由于map也是一个引用数据类型,因此如果声明未赋值时不会开辟空间,也不会进行初始化,同样需要通过make函数进行初始化,语法如下:
var map_name = make(map[key_type]value_type)
// 先声明 var stu = make(map[string]string) // 再赋值 stu["name"] = "zhangsan" stu["age"] = "21" fmt.println(stu)
❗ 注意:
map当中的键是无序的,因此每次打印的顺序不一定相同
map当中的键是唯一的、不重复的
初始化方式2:使用符合字面量声明并赋值
语法如下:
var map_name = map[key_type]value_type{"key1": value1, "key2": value2...}// 声明并赋值
var stumap = map[string]string{"name": "zhansgan", "age": "21"}
fmt.println(stumap)
语法格式:map_name[key] = value
如果在map当中没有对应的key时就会进行新增
// map的新增操作 var stumap = make(map[string]string) stumap["name"] = "zhangsan" stumap["age"] = "21" fmt.println(stumap)
程序运行结果:

语法格式:map_name[key] = value
与新增操作不同:当map中已经有该key键时,就会将对应的value进行修改
// map的修改操作 var stumap = make(map[string]string) // 新增name stumap["name"] = "zhangsan" fmt.println(stumap) // 修改name stumap["name"] = "lisi" fmt.println(stumap)
程序运行结果:

语法格式:var value, exists = map_name[key]
// map的查询操作
var stumap = make(map[string]string)
// 新增name
stumap["name"] = "zhansgan"
// 查询name
name, exists := stumap["name"]
if exists {
fmt.println("name值为: " + name)
} else {
fmt.println("name不存在!")
}
// 查询age
age, exists := stumap["age"]
if exists {
fmt.println("age值为: " + age)
} else {
fmt.println("age不存在!")
}
程序运行结果:

语法格式:delete(map_name, key)
map的删除则需要使用到内置delete函数,第一个参数为map对象,第二个参数为待删除的key值
// map的删除操作 var stumap = make(map[string]string) // 新增name stumap["name"] = "zhansgan" fmt.println(stumap) // 删除name delete(stumap, "name") fmt.println(stumap)
程序运行结果:

语法格式:for k, v := range map_name {}
与数组切片不同,数组切片既可以通过索引下标进行遍历,也可以通过range迭代遍历。但是map没有索引这个概念,因此只能通过range进行迭代遍历
// map的遍历操作
var stumap = make(map[string]string)
// 新增name,age,id
stumap["name"] = "zhansgan"
stumap["age"] = "21"
stumap["id"] = "1001"
// range遍历
for k, v := range stumap {
fmt.println(k, v)
}
程序运行结果:

到此这篇关于go中map数据类型的实现的文章就介绍到这了,更多相关go map数据类型内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!
您想发表意见!!点此发布评论
版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。
发表评论