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. Java常用类库2

    1.java.util.Date类 package LESSON9; import java.util.Date; public class demo1 { public static void ma ...

  2. 深入了解typeof与instanceof的使用场景及注意事项

    JavaScript中的数据类型分为两类,undefined,number,boolean,string,symbol,bigint,null[1]组成的基础类型和Object.Function.Ar ...

  3. 手摸手带你学移动端WEB开发

    HTML常用标签总结 手摸手带你学CSS HTML5与CSS3知识点总结 手摸手带你学移动端WEB开发 好好学习,天天向上 本文已收录至我的Github仓库DayDayUP:github.com/Ro ...

  4. Chapter Zero 0.1.4 计算机上常用的计算单位

    0.1 计算机硬件 计算机上常用的计算单位 容量单位: 计算机对于数据的判断依据有没有通电来记录信息,对于每个记录而言, 他只认识0或1,而0/1这个二进制单位我们成为bit. 因为bit太小,所以存 ...

  5. 使VS开发的程序在Win7系统运行时自动提升权限

    软件开发时,总是会遇到在Win7系统上运行不起来或者异常的情况,这通常是用户的权限不够引起的. 下面提供一个可以使程序运行时,自动提升用户权限的方法. 1.右键点击启动项目,单击"属性&qu ...

  6. codeforces 1019B The hat 【交互题+二分搜索】

    题目链接:戳这里 学习题解:戳这里

  7. CodeForces 348D Turtles(LGV定理)题解

    题意:两只乌龟从1 1走到n m,只能走没有'#'的位置,问你两只乌龟走的时候不见面的路径走法有几种 思路:LGV定理模板.但是定理中只能从n个不同起点走向n个不同终点,那么需要转化.显然必有一只从1 ...

  8. webpack remove console.log

    webpack remove console.log https://stackoverflow.com/questions/41040266/remove-console-logs-with-web ...

  9. 如何在手机上实现 H5 页面全屏显示

    如何在手机上实现 H5 页面全屏显示 fullscreen 隐藏头部地址栏 隐藏底部导航栏 refs xgqfrms 2012-2020 www.cnblogs.com 发布文章使用:只允许注册用户才 ...

  10. LeetCode 最大收益的分配工作

    LeetCode 最大收益的分配工作 工作安排 现在有n位工程师和6项工作(编号为0至5),现在给出每个人能够胜任的工作序号表(用一个字符串表示,比如:045,表示某位工程师能够胜任0号,4号,5号工 ...