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的更多相关文章

  1. mapreduce中一个map多个输入路径

    package duogemap; import java.io.IOException; import java.util.ArrayList; import java.util.List; imp ...

  2. .NET Core中间件的注册和管道的构建(3) ---- 使用Map/MapWhen扩展方法

    .NET Core中间件的注册和管道的构建(3) ---- 使用Map/MapWhen扩展方法 0x00 为什么需要Map(MapWhen)扩展 如果业务逻辑比较简单的话,一条主管道就够了,确实用不到 ...

  3. Java基础Map接口+Collections工具类

    1.Map中我们主要讲两个接口 HashMap  与   LinkedHashMap (1)其中LinkedHashMap是有序的  怎么存怎么取出来 我们讲一下Map的增删改查功能: /* * Ma ...

  4. Java基础Map接口+Collections

    1.Map中我们主要讲两个接口 HashMap  与   LinkedHashMap (1)其中LinkedHashMap是有序的  怎么存怎么取出来 我们讲一下Map的增删改查功能: /* * Ma ...

  5. 多用多学之Java中的Set,List,Map

            很长时间以来一直代码中用的比较多的数据列表主要是List,而且都是ArrayList,感觉有这个玩意就够了.ArrayList是用于实现动态数组的包装工具类,这样写代码的时候就可以拉进 ...

  6. Java版本:识别Json字符串并分隔成Map集合

    前言: 最近又看了点Java的知识,于是想着把CYQ.Data V5迁移到Java版本. 过程发现坑很多,理论上看大部分很相似,实践上代码写起来发现大部分都要重新思考方案. 遇到的C#转Java的一些 ...

  7. MapReduce剖析笔记之八: Map输出数据的处理类MapOutputBuffer分析

    在上一节我们分析了Child子进程启动,处理Map.Reduce任务的主要过程,但对于一些细节没有分析,这一节主要对MapOutputBuffer这个关键类进行分析. MapOutputBuffer顾 ...

  8. MapReduce剖析笔记之七:Child子进程处理Map和Reduce任务的主要流程

    在上一节我们分析了TaskTracker如何对JobTracker分配过来的任务进行初始化,并创建各类JVM启动所需的信息,最终创建JVM的整个过程,本节我们继续来看,JVM启动后,执行的是Child ...

  9. MapReduce剖析笔记之五:Map与Reduce任务分配过程

    在上一节分析了TaskTracker和JobTracker之间通过周期的心跳消息获取任务分配结果的过程.中间留了一个问题,就是任务到底是怎么分配的.任务的分配自然是由JobTracker做出来的,具体 ...

  10. MapReduce剖析笔记之三:Job的Map/Reduce Task初始化

    上一节分析了Job由JobClient提交到JobTracker的流程,利用RPC机制,JobTracker接收到Job ID和Job所在HDFS的目录,够早了JobInProgress对象,丢入队列 ...

随机推荐

  1. redis分布式锁的这些坑,我怀疑你是假的开发

    摘要:用锁遇到过哪些问题? 一.白话分布式 什么是分布式,用最简单的话来说,就是为了较低单个服务器的压力,将功能分布在不同的机器上面:就比如: 本来一个程序员可以完成一个项目:需求->设计-&g ...

  2. git从安装到多账户操作一套搞定(一)入门使用

    作者:良知犹存 转载授权以及围观:欢迎添加微信:Allen-Iverson-me-LYN 总述     GIT是当今热门代码管理技术,但是如此火的系统,竟然是大神林纳斯花了两周用C写出来的一个分布式版 ...

  3. 2019牛客暑期多校训练营(第五场)E.independent set 1(状压dp)

    题意:给你n个点 m条边 问你所有子图的最大独立集的和 思路:我们可以设f state 为当前点集下的最大独立集的大小 所以我们可以把集合分为两个部分 绝对包含了这个一个点 绝对不包含这个点 两种情况 ...

  4. Codeforces Round #641 (Div. 2)

    只写了A~D A - Orac and Factors 题意:f(n)就是n的第二小因数,问执行k次 n=f(n)+n 后的结果. 题解:如果一直找第二小的因子的话,1e9肯定得t.看下边样例解释就会 ...

  5. LianLianKan HDU - 4272 状压dp

    题意:长度为n(n<=1000)的栈,栈顶元素可以与下面1~5个数中相同的元素消去,问最后能都完全消去. 题解: 比如这个序列12345678910112这个位置的最远可匹配位置能到11为什么呢 ...

  6. C# 静态类 单例模式 对比

    公司的类都需要使用单例模式实现,这个可以节省资源,避免重复对象的生成.但是静态类也可以做到这一点,而且写起来更简洁,于是查阅相关资料,希望弄明白两者的差别. 1.单例模式可以在用到的时候初始化,而静态 ...

  7. Linux-平均负载指数

    目录 系统平均负载 什么是平均负载 平均负载多少合理 如何观察平均负载 平均负载和CPU的使用率的区别 平均负载分析 执行CPU密集型任务 执行I/O密集型任务 大量进程调度 关于平均负载的总结 系统 ...

  8. 超详细 DNS 协议解析

    尽人事,听天命.博主东南大学研究生在读,热爱健身和篮球,正在为两年后的秋招准备中,乐于分享技术相关的所见所得,关注公众号 @ 飞天小牛肉,第一时间获取文章更新,成长的路上我们一起进步 本文已收录于 C ...

  9. 1054D Changing Array 【位运算+思维】

    题目:戳这里 题意:两个数n,k,满足给的n个数小于2的k次方.每个数可以进行一次操作,即把a[i]换成a[i]^(1<<k-1);求最多的连续区间数使得 区间[L,R] (1<=L ...

  10. POJ - 3280 Cheapest Palindrome 【区间dp】【非原创】

    Keeping track of all the cows can be a tricky task so Farmer John has installed a system to automate ...