Go的map
map
相当于python中的字典。
一、map的创建
map 在定义时,key(数字和字符串)和value的类型固定了,且key只能用数字和字符串。
1、map的类型
map[key的类型]value的类型
2、定义并初始化
var dic map[int]string //这样声明只是nil类型
map想要使用需要初始化
// 方法一:make(map类型)
var dic map[int]string = make(map[int]string)
dic[1] = "donner"
// 方法二:赋值为 map类型+{}
var dic = map[int]string{}
dic[1] = "donner"
dic := map[int]string{}
dic[1] = "donner"
fmt.Println(dic)
二、给map添加元素
map[索引] = 值添加元素。
var dic = map[int]string{}
dic[1] = "donner"
三、获取map的元素
获取 map 元素的语法是 map[key] 。
var dic = map[int]string{1:"a",2:"b",3:"c"}
ele := dic[1]
fmt.Println(ele) // a
el2 := dic[8]
fmt.Println(el2) // "" 没有设值的,会取value类型的默认值
从字典中取值,其实会返回两个值,一个是真正的值,一个是true或false。
如果用一个变量来接,就是值;两个变量接,一个是值,一个是true或false。
var dic = map[int]string{1:"a",2:"b",3:"c"}
el3,is_ex := dic[2]
fmt.Println(el3,is_ex) // b true
el4,is_ex := dic[4]
fmt.Println(el4,is_ex) // "" false
四、删除map的元素
根据key删除值,语法是 delete(map, key)。这个函数没有返回值。
var dic = map[int]string{1:"a",2:"b",3:"c"}
fmt.Println(dic) // map[1:a 2:b 3:c]
delete(dic,1)
fmt.Println(dic) // map[2:b 3:c]
五、获取map的长度
var dic = map[int]string{1:"a",2:"b",3:"c"}
fmt.Println(dic) // map[1:a 2:b 3:c]
fmt.Println(len(dic)) // 3
dic[4] = "d"
fmt.Println(dic) // map[1:a 2:b 3:c 4:d]
fmt.Println(len(dic)) // 4
六、map的类型
map是引用类型,修改传参的map也会修改原map。
var dic = map[int]string{1:"a",2:"b",3:"c"}
fmt.Println(dic) // map[1:a 2:b 3:c]
change_dic(dic) // map[1:change 2:b 3:c]
fmt.Println(dic) // map[1:change 2:b 3:c]
func change_dic(d map[int]string) {
d[1] = "change"
fmt.Println(d)
}
七、map的相等性
map 之间不能使用 == 操作符判断,== 只能用来检查 map 是否为 nil。
map1 := map[string]int{
"one": 1,
"two": 2,
}
map2 := map1
if map1 == map2 { // 直接划红线报错
}
// invalid operation: map1 == map2 (map can only be compared to nil)
八、循环map
只能用range循环遍历map,不能用i初始化的方式。
var dic = map[int]string{1:"a",2:"b",3:"c",4:"d"}
for k,v:=range dic{
fmt.Println(k,v)
}
1 a
2 b
3 c
4 d
Go的map的更多相关文章
- mapreduce中一个map多个输入路径
package duogemap; import java.io.IOException; import java.util.ArrayList; import java.util.List; imp ...
- .NET Core中间件的注册和管道的构建(3) ---- 使用Map/MapWhen扩展方法
.NET Core中间件的注册和管道的构建(3) ---- 使用Map/MapWhen扩展方法 0x00 为什么需要Map(MapWhen)扩展 如果业务逻辑比较简单的话,一条主管道就够了,确实用不到 ...
- Java基础Map接口+Collections工具类
1.Map中我们主要讲两个接口 HashMap 与 LinkedHashMap (1)其中LinkedHashMap是有序的 怎么存怎么取出来 我们讲一下Map的增删改查功能: /* * Ma ...
- Java基础Map接口+Collections
1.Map中我们主要讲两个接口 HashMap 与 LinkedHashMap (1)其中LinkedHashMap是有序的 怎么存怎么取出来 我们讲一下Map的增删改查功能: /* * Ma ...
- 多用多学之Java中的Set,List,Map
很长时间以来一直代码中用的比较多的数据列表主要是List,而且都是ArrayList,感觉有这个玩意就够了.ArrayList是用于实现动态数组的包装工具类,这样写代码的时候就可以拉进 ...
- Java版本:识别Json字符串并分隔成Map集合
前言: 最近又看了点Java的知识,于是想着把CYQ.Data V5迁移到Java版本. 过程发现坑很多,理论上看大部分很相似,实践上代码写起来发现大部分都要重新思考方案. 遇到的C#转Java的一些 ...
- MapReduce剖析笔记之八: Map输出数据的处理类MapOutputBuffer分析
在上一节我们分析了Child子进程启动,处理Map.Reduce任务的主要过程,但对于一些细节没有分析,这一节主要对MapOutputBuffer这个关键类进行分析. MapOutputBuffer顾 ...
- MapReduce剖析笔记之七:Child子进程处理Map和Reduce任务的主要流程
在上一节我们分析了TaskTracker如何对JobTracker分配过来的任务进行初始化,并创建各类JVM启动所需的信息,最终创建JVM的整个过程,本节我们继续来看,JVM启动后,执行的是Child ...
- MapReduce剖析笔记之五:Map与Reduce任务分配过程
在上一节分析了TaskTracker和JobTracker之间通过周期的心跳消息获取任务分配结果的过程.中间留了一个问题,就是任务到底是怎么分配的.任务的分配自然是由JobTracker做出来的,具体 ...
- MapReduce剖析笔记之三:Job的Map/Reduce Task初始化
上一节分析了Job由JobClient提交到JobTracker的流程,利用RPC机制,JobTracker接收到Job ID和Job所在HDFS的目录,够早了JobInProgress对象,丢入队列 ...
随机推荐
- jvm-本地方法接口
什么是本地方法 简单地讲,一个Native Methodt是一个Java调用非Java代码的接囗.一个Native Method是这样一个Java方法:该方法的实现由非Java语言实现,比如C.这个特 ...
- Codeforces Round #657 (Div. 2) B. Dubious Cyrpto(数论)
题目链接:https://codeforces.com/contest/1379/problem/B 题意 给出三个正整数 $l,r,m$,判断在区间 $[l,r]$ 内是否有 $a,b,c$ 满足存 ...
- 2019HDU多校 Round6
Solved:2 02 Nonsense Time (LIS) 题意:给定一个全排列 最开始为空的 每秒中一个位置上的数出现 求每秒的LIS 题解:题解说 考虑时光倒流 倒着消掉 因为数据随机 所以期 ...
- 灯光照射,圆形探测类问题(解题报告)<分层差分><cmath取整>
题目描述 一个n*n的网格图上有m个探测器,每个探测器有个探测半径r,问这n*n个点中有多少个点能被探测到. 输入输出格式 输入格式: (1<=r<n<=5000) (1<=m ...
- zjnu1757Excellent (数学公式)
Description Let us begin with a positive integer N and find the smallest positive integer which does ...
- Codeforces Round #660 (Div. 2) Captain Flint and Treasure 拓扑排序(按照出度、入读两边拓扑排序)
题目链接:Captain Flint and Treasure 题意: 一种操作为 选一个下标 使得ans+=a[i] 且 把a[b[i]]+a[i] 要求每个下标都进行一种这样的操作,问怎么样的 ...
- 郁闷的出纳员 HYSBZ - 1503
OIER公司是一家大型专业化软件公司,有着数以万计的员工.作为一名出纳员,我的任务之一便是统计每位员工的 工资.这本来是一份不错的工作,但是令人郁闷的是,我们的老板反复无常,经常调整员工的工资.如果他 ...
- Codeforces Round #663 (Div. 2) C. Cyclic Permutations (构造,图?)
题意:对于某个序列,若\(1\le i\le n\),\(1\le j\le i\)且\(p_j>p_i\),或者\(1\le i\le n\),\(i<j \le n\)且\(p_j&g ...
- windows 系统下安装kibana和sense
目前最新版本已经不需要安装sense了,而是使用Dev Tools工具: 下面进行下载和安装kibana. 点击下载:https://artifacts.elastic.co/downloads/ki ...
- 根据直方图 histogram 进行简单的图像检索
https://github.com/TouwaErioH/Machine-Learning/tree/master/image%20identification/Histogram%20retrie ...