九、map

9.1 map介绍

map是key-value数据结构,又称为字段或者关联数组,类似其他编程语言的集合,在编程中是经常使用到

9.2 基本语法

var map变量名 [map] [keytype]valuetype

key可以是什么类型?

Golang中的map的key可以是很多种类型,比如:bool、数字、string、指针、channel、还可以是只包含前面几个类型的接口,结构体,数组,通常为int、string

注意:slice、map还有funcation不可以,因为这几个没法用 == 来判断

valuetype可以是什么类型

valuetype的类型和key一样,通常为:数字(整数,浮点数),string,map,struct

注意:声明是不会分配内存的,初始化需要make,分配内存后才能赋值和使用

43353535.PNG

对上面代码的说明

1、map在使用前一定要make

2、map的key是不能重复的的,如果重复了, 则以最后这个key-value为准

3、map的value是可以相同的

4、map的key-value是无序的

5、make内置函数的说明

43353535.PNG

9.3 map的使用

9.3.1 方式1

43353535.PNG

9.3.2 方式2(建议)

43353535.PNG

9.3.3 方式3

43353535.PNG

9.3.4 案例

演示一个key-value的value是map的案例,比如:我们要存放3个学生信息,每个学生和呢个有name和sex信息

43353535.PNG

9.4 map的增删改查

9.4.1 map增加和更新

map["key"] = value 如果key还没有,就是增加,如果key存在就是修改

43353535.PNG

9.4.2 map删除

说明:

delete(map,"key"),delete是一个内置函数,如果key存在,就删除该key-value,如果key不存在,但是也不会报错

43353535.PNG

代码

43353535.PNG

细节

1、如果我们要删除map的所有key,没有一个专门的方法一次删除,可以遍历一下key,逐个删除

2、或者 map = make(...) make一个新的,让原来的成为垃圾,被GC回收

43353535.PNG

9.4.3 map查找

43353535.PNG

9.4.4 map遍历

案例演示相对复杂的map遍历,该map的value又是map

t2w9Zq.png

9.4.5 map的长度

t2wylQ.png

案例:fmt.Println(len(stus))

t2wjk6.png

9.4.6 map切片

基本介绍

切片的数据类型如果是map,则我们称为 slice of map ,map切片,这样使用则map个数就可以动态变化了

案例

要求:使用一个map来记录monster的信息name和age,也就是说一个monster对应一个map,并且妖怪的个数是可以动态增加 = > map切片

65785858.PNG

9.4.7 map的排序

基本介绍

  • Golang中没有一个专门的方法针对map的key进行排序

  • Golang中的map默认是无序的,注意也不是按照添加的顺序存放的,你每次遍历,得到的输出可能不一样

  • Golang中的map排序,是先将key进行排序,然后根据key值遍历输出即可

package main
import (
	"fmt"
	"sort"
)
func main() {
	map1 := make(map[int]int, 10)
	map1[10] = 100
	map1[1] = 13
	map1[4] = 56
	map1[8] = 78

	fmt.Println(map1)
	// 如果按照map的key的顺序进行排序输出
	// 1、先将map的key放入到 切片中
	// 2、对切片进行排序
	// 3、遍历切片,然后按照key来输出map的值

	var keys []int
	for k, _ := range map1 {
		keys = append(keys, k)
	}
	// 排序
		sort.Ints(keys)
		fmt.Println(keys)

		for _, k := range keys {
			fmt.Printf("map[%v]=%v \n", k, map1[k])
		}
}

9.5 map使用细节

  • map是引用类型,遵守引用类型传递的机制,在一个函数接收map,修改后,会直接修改原来的map

t2TVUK.png

  • map的容量达到后,再想map增加元素,会紫东阁扩容,并不会发生panic,也就是说map能动态的增长 键值对(key-value)
  • map 的 value 也经常使用struct类型,更适合管理复杂的数据(比前面value是一个map更好),比如:value为Student结构体

9.6 map综合练习

  • 使用 map[string]map[string]string的map类型

  • key:表示用户名,是唯一的,不可以重复

  • 如果某个用户名存在,就将其密码改为“8888888” ,如果不存在就增加这个用户信息(包括昵称nickname 和密码 pwd)

  • 编写一个函数 modifyUser(users map[string]map[string]string, name string)完成上述功能

package main
import (
	"fmt"
)

func modifyUser(users map[string]map[string]string,  name string) {
	// 判断users中是否有name
	// v, ok := users[name]
	if users[name] != nil {
		// 有这个用户
		users[name]["pwd"] = "88888888"
	} else {
		// 没有这个用户
		users[name] = make(map[string]string, 2)
		users[name]["pwd"] = "8888888"
		users[name]["nickname"] = "昵称~" + name //示意
	}
}

func main() {
	users := make(map[string]map[string]string, 10)
	users["smith"] = make(map[string]string, 2)
	users["smith"]["pwd"] = "99999"
	users["smith"]["nickname"] = "小花猫"
	modifyUser(users, "tom")
	modifyUser(users, "marry")
	modifyUser(users, "smith")
	fmt.Println(users)
}

结果为

t2Ho9O.png

posted on 2020-06-07 14:38  九酒馆  阅读(375)  评论(0编辑  收藏  举报

导航