欢迎您的访问
专注架构,Java,数据结构算法,Python技术分享

golang教程(九):map

一、map 的基本介绍

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

二、map 的声明

1、基本语法

var map 变量名 map[keytype]valuetype

 

  • key 可以是什么类型

golang 中的 map,的 key 可以是很多种类型,比如 bool, 数字,string, 指针, channel , 还可以是只
包含前面几个类型的 接口, 结构体, 数组
通常 key 为 int 、string
注意: slice, map 还有 function 不可以,因为这几个没法用 == 来判断

  • valuetype 可以是什么类型

valuetype 的类型和 key 基本一样,这里我就不再赘述了
通常为: 数字(整数,浮点数),string,map,struct

示例

var a map[string]string
var a map[string]int
var a map[int]string
var a map[string]map[string]string

 

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

2、分配空间

使用make函数为map分配内存空间
在这里插入图片描述

func main() {
	var m = make(map[int]interface{},1)
	m[1]="A"
	m[2]="B"
	fmt.Printf("m地址:%p;m的值:%v",m,m)
}

 

m地址:0xc00005c150;m的值:map[1:A 2:B]

 

三、map 的使用

1、方式 1

见前面的例子

2、方式 2

不指定长度

func main() {
	var m = make(map[int]interface{})
	m[1]="A"
	m[2]="B"
	fmt.Printf("m地址:%p;m的值:%v",m,m)
}

 

m地址:0xc00005c150;m的值:map[1:A 2:B]

 

3、方式 3

直接声明并赋值,注意最后要加上,

func main() {
	var m = map[int]interface{}{
		1:"A",
		2:"B",
	}
	fmt.Printf("m地址:%p;m的值:%v",m,m)
}

 

m地址:0xc000070150;m的值:map[2:B 1:A]

 

四、map 操作

1、map 增加和更新:

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

2、map 删除:

delete(map,“key”) ,delete 是一个内置函数,如果 key 存在,就删除该 key-value,如果 key 不存在,
不操作,但是也不会报错
在这里插入图片描述
如果我们要删除 map 的所有 key ,没有一个专门的方法一次删除,可以遍历一下 key, 逐个删除
或者 map = make(…),make 一个新的,让原来的成为垃圾,被 gc 回收

3、map 查找

value := m[key]

如果 m这个 map 中存在 key , 那么 返回 对应的value,否则返回 对应value类型的默认值

4、map 遍历

map 的遍历使用 for-range 的结构遍历

综合示例

func main() {
	var m = map[int]interface{}{
		1:"A",
		2:"B",
	}

	fmt.Printf("m地址:%p;m的值:%v\n",m,m)
	//添加
	m[3]="C"
	fmt.Printf("m地址:%p;m的值:%v\n",m,m)
	//更新
	m[2]= "H"
	//删除
	delete(m,3)
	//遍历
	for key,value:= range m{
		fmt.Printf("key:%v ; value:%v\n",key,value)
	}
	fmt.Printf("m地址:%p;m的值:%v\n",m,m)
}

 

m地址:0xc00005c150;m的值:map[1:A 2:B]
m地址:0xc00005c150;m的值:map[1:A 2:B 3:C]
key:1 ; value:A
key:2 ; value:H
m地址:0xc00005c150;m的值:map[2:H 1:A]

 

五、总结:

  1. map 在使用前一定要 make
  2. map 的 key 是不能重复,如果重复了,则以最后这个 key-value 为准
  3. map 的 value 是可以相同的. 4) map 的 key-value 是无序
  4. map 是引用类型,遵守引用类型传递的机制,在一个函数接收 map,修改后,会直接修改原来
    的 map
  5. map 的容量达到后,再想 map 增加元素,会自动扩容,并不会发生 panic,也就是说 map 能动
    态的增长 键值对(key-value)
  6. map 的 value 也经常使用 struct 类型,更适合管理复杂的数据(比前面 value 是一个 map 更好),比如 value 为 Student 结构体

作者:iRich_全栈 | 来源:http://39sd.cn/E9F10

赞(1) 打赏
版权归原创作者所有,任何形式转载请联系作者;码农code之路 博客站点 » golang教程(九):map

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

微信扫一扫打赏