原文地址:

http://www.limerence2017.com/2019/06/11/golang06/

基本用法

map同样也是引用类型,map在使用前需要通过make进行初始化,否则会报panic错误。

map 初始化和插入

1
2
3
4
5
6
7
8
9
10
type PersonInfo struct {
ID string
Name string
Address string
} var personDB map[string]PersonInfo
personDB = make(map[string]PersonInfo)
personDB["12345"] = PersonInfo{"12345", "Tom", "Room 203"}
personDB["1"] = PersonInfo{"1", "Jack", "Room 102"}

可以看到map使用前用make先构造初始化,之后进行了插入,如果key存在,则修改value

map 查找

1
2
3
4
5
6
7
//从这个map查找键为"1234"
person, ok := personDB["1234"]
if ok {
fmt.Println("Found person", person.Name, "with ID 1234")
} else {
fmt.Println("Did not find person with ID 1234")
}

查找指定key,返回值为value和bool类型结果,所以先判断bool类型值是否为true

map 进阶

map可以直接显示初始化不需要make构造。

1
var data map[string]int = map[string]int{"bob": 18, "luce": 28}

map是引用类型,函数通过修改形参,达到修改外部实参的功能

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
func modify(data map[string]int, key string, value int) {
v, res := data[key]
//不存在,则res是false
if !res {
fmt.Println("key not find")
return
}
fmt.Println("key is ", key, "value is ", v)
data[key] = value
} func main() {
var data map[string]int = map[string]int{"bob": 18, "luce": 28}
modify(data, "lilei", 28)
modify(data, "luce", 22)
fmt.Println(data)
}

map 大小可以通过len函数获得,如果不采用显示初始化方式,只声明map,在使用前一定要make初始化
map遍历采用range方式,且map是无序的,切记。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
//map大小
fmt.Println(len(data))
//map 使用前一定要初始化,可以显示初始化,也可以用make
var data2 map[string]int = make(map[string]int, 3)
fmt.Println(data2)
//当key不存在时,则会插入
data2["sven"] = 19
fmt.Println(data2)
//当key存在时,则修改
data2["sven"] = 299
fmt.Println(data2)
data2["Arean"] = 33
data2["bob"] = 178
//map是无序的,遍历输出
for key, value := range data2 {
fmt.Println("key: ", key, "value: ", value)
}

上面的代码遍历map,打印结果为

1
2
3
key:  bob value:  178
key: sven value: 299
key: Arean value: 33

可以实现一个函数,将map中的key存到slice中,然后排序,之后根据排好顺序的slice遍历
得到的就是排序后的结果

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
func sortprintmap(data map[string]int) {
slice := make([]string, 0)
for k, _ := range data {
slice = append(slice, k)
}
sort.Strings(slice)
for _, s := range slice {
d, e := data[s]
if !e {
continue
}
fmt.Println("key is ", s, "value is ", d) }
}

在main函数调用sortprintmap(data2),结果如下

1
2
3
key is  Arean value is  33
key is bob value is 178
key is sven value is 299

二维map

二维map操作和之前类似,只是声明时value还是一个map

1
2
//二维map
var usrdata map[string]map[string]int

二维map同样遵循使用前先make初始化原则,并且在二层map要使用前仍然需要make

1
2
3
4
5
6
7
8
9
//使用前需要初始化
usrdata = make(map[string]map[string]int)
usrdata["sven"] = make(map[string]int)
usrdata["sven"]["age"] = 21
usrdata["sven"]["id"] = 1024 usrdata["susan"] = make(map[string]int)
usrdata["susan"]["age"] = 19
usrdata["susan"]["id"] = 1000

二维map遍历

1
2
3
4
5
6
//二维map 遍历
for k, v := range usrdata {
for k2, v2 := range v {
fmt.Println(k, " ", k2, " ", v2)
}
}

slice 中存储map

1
2
3
4
5
6
7
//slice of map
slicem := make([]map[string]int, 5)
for i := 0; i < len(slicem); i++ {
slicem[i] = make(map[string]int)
} fmt.Println(slicem)

本着golang所有引用类型,如chan,map,slice,interface,使用前都需要make初始化。
上面代码先初始化slicem,然后再遍历slice,为每个元素初始化map类型

map 反转

1
2
3
4
5
6
7
//map 反转
rvmap := make(map[int]string)
for k, v := range data2 {
rvmap[v] = k
}
fmt.Println(rvmap)
fmt.Println(data2)

其实就是构造一个和原map 的key value相反的map,然后为该map初始化并且插入元素。

上述所有源码下载地址
源码下载地址
谢谢关注我的公众号

Go(05)map介绍的更多相关文章

  1. go语言基础之map介绍和使用

    1.map介绍 Go语言中的map(映射.字典)是一种内置的数据结构,它是一个无序的key—value对的集合,比如以身份证号作为唯一键来标识一个人的信息. 2.map示例 map格式为: map[k ...

  2. java集合系列——Map介绍(七)

    一.Map概述 0.前言 首先介绍Map集合,因为Set的实现类都是基于Map来实现的(如,HashSet是通过HashMap实现的,TreeSet是通过TreeMap实现的). 1:介绍 将键映射到 ...

  3. perl中的默认变量与Z/map介绍

    use v6; =begin pod @*ARGS 命令行参数, 不含脚本名 $*PROGRAM-NAME:当前运行脚本的相对路径 $*PROGRAM:当前运行脚本的文件名称 $*CWD:当前工作路径 ...

  4. iOS开发多线程篇 05 —GCD介绍

    iOS开发多线程篇—GCD介绍 一.简单介绍 1.什么是GCD? 全称是Grand Central Dispatch,可译为“牛逼的中枢调度器” 纯C语言,提供了非常多强大的函数 2.GCD的优势 G ...

  5. 几种线程相关的map介绍

    Java中平时用的最多的Map集合就是HashMap了,它是线程不安全的. 看下面两个场景: 1.当用在方法内的局部变量时,局部变量属于当前线程级别的变量,其他线程访问不了,所以这时也不存在线程安全不 ...

  6. java集合系列——Map之HashMap介绍(八)

    1.HashMap的简介 (JDK1.7.0_79版本) HashMap是基于哈希表的Map实现的的,一个Key对应一个Value,允许使用null键和null值,不保证映射的顺序,特别是它不保证该顺 ...

  7. Map集合、散列表、红黑树介绍

    前言 声明,本文用得是jdk1.8 前面已经讲了Collection的总览和剖析List集合: Collection总览 List集合就这么简单[源码剖析] 原本我是打算继续将Collection下的 ...

  8. map,hash_map和unordered_map 实现比较

    map介绍 Map是STL[1]的一个关联容器,它提供一对一(其中第一个可以称为关键字,每个关键字只能在map中出现一次,第二个可能称为该关键字的值)的数据处理能力,由于这个特性,它完成有可能在我们处 ...

  9. JavaScript之Map对象

    前言 工欲善其事,必先利其器.这是一款以前在前端项目中没有使用过的.有趣的对象,咱来看看如何使用~ 并非arrayObj.map(function) //arrayObj.map与arrayObj.f ...

随机推荐

  1. The Preliminary Contest for ICPC Asia Nanchang 2019 E. Magic Master

    题目:https://nanti.jisuanke.com/t/41352 思路:约瑟夫环 由题意得第k张牌即求 k 为 第几个 报数为m+1 的单位 用队列模拟即可 #include<bits ...

  2. Java使用freemarker导出word文档

    通过freemarker,以及JAVA,导出word文档. 共分为三步: 第一步:创建模板文件 第二步:通过JAVA创建返回值. 第三步:执行 分别介绍如下: 第一步: 首先创建word文档,按照想要 ...

  3. 一个原生ajax在jetbrains开发平台的调用方法

    这段随笔的记述目的无非是,一个html页面中可能有多段js代码,所以采用外引的方法应该会好一些 function checkfiles() { var xhr = new XMLHttpRequest ...

  4. mybatis之联表查询

    今天碰到了一个问题,就是要在三张表里面各取一部分数据然后组成一个list传到前台页面显示.但是并不想在后台做太多判断,(因为涉及到for循环)会拉慢运行速度.正好用的框架是spring+springM ...

  5. Acwing-101-最高的牛(差分)

    链接: https://www.acwing.com/problem/content/103/ 题意: 有 N 头牛站成一行,被编队为1.2.3-N,每头牛的身高都为整数. 当且仅当两头牛中间的牛身高 ...

  6. 自定义 Swiper 的上一页,下一页按钮

    1. Swiper 的上一页,下一页按钮,不是必需包含在container 中的 2. 定义上一页,下一页按钮的样式,CSS略.... 3. 在初始化Swiper中,定义上一页,下一页按钮

  7. Redis常用数据类型底层数据结构分析

    Redis是一种键值(key-Value)数据库,相对于关系型数据库,它也被叫作非关系型数据库 Redis中,键的数据类型是字符串,但是为了非富数据存储方式,方便开发者使用,值的数据类型有很多 字符串 ...

  8. Linux系统下使用 mail 发送邮件

    邮件常常是Linux下监控报警手段之一.Linux下的mail命令可以方便,快速的完成发送邮件.下面以CentOS为例 1.安装: [app@127-0-0-1 ~]# mail -bash: mai ...

  9. jquery enabled选择器 语法

    jquery enabled选择器 语法 作用::enabled 选择器选取所有启用的表单元素.大理石平台精度等级 语法:$(":enabled") jquery enabled选 ...

  10. 4.JSP内置对象

    JSP内置对象,JSP提供了由容器实现和管理的内置对象,也可以称之为隐含对象,这些内置对象不需要通过 JSP页面编写来实例化,在所有的JSP页面中都可以直接使用,它起到了简化页面的作用. 在JSP中一 ...