跟着码术一起学习Golang语言。今天学习的是Go语言内置的数据结构:字典(map)。

----------------------------------------------------------------------------------------------------------------------------------------------------------------------------

字典(Map)

字典(map)是Go语言内置的数据结构,一组键值对的无序集合。

有些地方称之为映射。本文中一律成为字典(map)。

字典(map)也叫做关联数组。因为数组通过索引来查找元素,而字典通过键(key)来查找元素。

字典(map)的容量只受到内存的限制。在一个字典中,所有的键都是唯一的,并且必须支持==和!=操作符的类型。如果试图赋值给同一个键,后赋值的值将会覆盖原有值。


map的创建和填充

map的定义有两种:

1、初始化数据的定义方式。

2、使用make函数来定义。

输出结果:

   Map literal at "one" is: 1

   Map created at "key2" is: 3.141590

   Map assigned at "two" is: 3

   Map literal at "ten" is: 0

其中mapLit使用方法一定义;而mapCreated使用方法二。

---------------------------------------------

map的使用过程中需要注意以下几点:

1、map是无序的,每次打印出来的map都不会一样,它不能够通过index获取,而必须通过key获取;

2、map的长度不是固定的。和slice类似,map也是一种引用类型;

3、内置的len函数同样适用于map,返回map拥有的key的数量;

4、map的值可以很方便的修改。


map的访问

当访问元素所对应的键存在于字典中,那么肯定没有问题,能够获得对应的元素。但是如果不存在呢?

这个时候会返回零值,对于字符串的零值就是"",对于整数的零值就是0.

但是会存在这样的情况:

这个时候会输出:0。但是这个就与A键值对应的值混淆了。Go提供一种方法来解决这个问题。

此时使用X["E"]有两个返回值。一个是值,一个是否存在该键的bool型变量。

也就是:

_, ok := map1[key1] // ok == true if key1 is present, false otherwise


map的删除元素

Go语言提供了内置函数delete,这个函数可以用来从字典中删除元素。

输出结果:

删除元素前map长度为4,删除之后长度为3.<这里使用len函数获取map的长度>。

此外,如果你试图删掉一个不存在于map的键,程序不会报错。只是不会对map有任何影响。


for...range结构

---------------------------------------------

for...range结构可以用于map。


for key, value := range map1 {

   //do something

}

第一返回值为键(key),第二个返回值为值(value)。这两个值是仅仅作用于for循环内部的局部变量。例如:

输出结果:


这里我们同时能看出,map是无序的。

---------------------------------------------

如果你只关心值(value),可以这么使用:

for _, value := range map1 {

//do something

}

输出结果:

---------------------------------------------

如果你只关心键(key),可以这么使用:

for key := range map1 {

   fmt.Printf(“key is: %d ”, key)

}

输出结果:

--------------------总结--------------------

到今天为止我们学习了go语言所有的内置类型。

​包括:布尔型、数值型、字符串、数组、slice和map。

---------------------------------------------

欢迎关注码术!一起学习Golang语言。