8 map的用法
what's map
go里面的map和python字典差不多。
- 类似其他语言中的哈希表或者字典,以key-value的形式存储的数据
- key必须是支持==或者!=比较运算的类型,不可以是函数、map或者slice
- map查找比线性搜索快很多,但比使用索引访问数据的类型慢100倍
- map使用make()创建,支持:= 这种简写方式
- make([keyType]valueType,cap),cap表示容量,可以省略
- 超出容量时会自动扩容,但尽量提供一个合理的初始值
- 使用len()获取元素个数
- 键值对不存在的时候自动添加,使用delete() 删除某键值对
- 使用for range 对 map 和slice 进行迭代操作
如何简单的创建map
请看代码例子:
func main() {
var m map[int]string
m = map[int]string{}
var m map[int]string = make(map[int]string) // 或者也可以这样写
n := make(map[int]string) // 或者这样写
fmt.Println(m)
}
map的简单用法
主要介绍如何给map添加值,怎么从map里面取值,怎么删除指定key的值在map里面
package main
import (
"fmt"
)
func main() {
m := make(map[int]string) // 创建map
m[1] = "ok" // 给map赋值
m[2] = "go"
a := m[2] // 取出key为1的值
delete(m, 1) // 删除指定key的值
fmt.Println(m, a)
}
map高级用法之一-两层map嵌套
- 在map里面在嵌套一层map
package main
import (
"fmt"
)
func main() {
m := make(map[int]map[int]string) // 申明一个m
m[1] = make(map[int]string) // 声明m[1]是一个map
m[1][1] = "OK" // 往m[1]里面开始插入值
fmt.Println(m)
}
- 多层嵌套的返回值
func main() {
m := make(map[int]map[int]string)
m[1] = make(map[int]string)
m[2] = make(map[int]string)
m[1][1] = "OK"
a, i := m[2][1] // 此时我们从未定义这个值的话,取这个值第一个a是空值,第二个i是false表示未定义,如果是true表示定义了
fmt.Println(m)
fmt.Println(a, i)
}
map高级用法之二-数组元素全是map与for循环遍历该数组
我们创建一个数组,数组的元素都是map,此时如果我们想遍历这个数组的元素,每个元素都赋值下,该怎么做?
- 错误做法:
func main() {
sm := make([]map[int]string, 5)
for _, v := range sm {
v = make(map[int]string, 1)
v[1] = "OK" // v只是这个map的一个拷贝,所以这个v即使做了赋值,也影响不到sm
fmt.Println(v)
}
fmt.Println(sm)
}
- 正确的做法:
func main() {
sm := make([]map[int]string, 5)
for i := range sm {
sm[i] = make(map[int]string, 1) // 直接把map给赋值,从而影响到sm
sm[i][1] = "OK"
}
fmt.Println(sm)
}
练习1: 如何对map 的可以进行排序
map的key是无序的,那么如何进行排序呢?请看下面的代码
package main
import (
"fmt"
"sort"
)
func main() {
m := map[int]string{1: "a", 2: "b", 3: "c", 4: "d", 5: "e"}
s := make([]int, len(m))
i := 0
for k, _ := range m {
s[i] = k
i++
}
sort.Ints(s)
fmt.Println(s)
}
练习2: 如何把一个map的K/V 对换位置
举个例子:
m:{1: "a", 2: "b", 3: "c", 4: "d", 5: "e"}
我对调下K/V的位置,结果如下:
m2: {c:3 d:4 e:5 a:1 b:2}
了解以后请看代码:
package main
import (
"fmt"
)
func main() {
m := map[int]string{1: "a", 2: "b", 3: "c", 4: "d", 5: "e"}
m2 := map[string]int{}
for k, v := range m {
m2[v] = k
}
fmt.Println("m", m)
fmt.Println("m2", m2)
}
8 map的用法的更多相关文章
- c++map的用法 分类: POJ 2015-06-19 18:36 11人阅读 评论(0) 收藏
c++map的用法 分类: 资料 2012-11-14 21:26 10573人阅读 评论(0) 收藏 举报 最全的c++map的用法 此文是复制来的0.0 1. map最基本的构造函数: map&l ...
- STL中map的用法
map是STL的一个关联容器,它提供一对一(其中第一个可以称为关键字,每个关键字只能在map中出现一次,第二个可能称为该关键字的值)的数据处理能力,由于这个特性,它完成有可能在我们处理一对一数据的时候 ...
- C++11中map的用法
最全的c++map的用法 1. map最基本的构造函数:map<string ,int>mapstring; map<int,string >mapint;map<sri ...
- entrySet用法 以及遍历map的用法
entrySet用法 以及遍历map的用法 keySet是键的集合,Set里面的类型即key的类型entrySet是 键-值 对的集合,Set里面的类型是Map.Entry 1.keySet( ...
- python map 常见用法
python map 常见用法2017年02月01日 19:32:41 淇怪君 阅读数:548版权声明:欢迎转载,转载请注明出处 https://blog.csdn.net/Tifficial/art ...
- forEach、for+i、map的用法及区别
array.forEach(callback[, thisObject]); 下面是参数的详细信息: 1. callback : 函数测试数组的每个元素. 2.thisObject : 对象作为该 ...
- set/multiset和map/multimap用法小结
二叉搜索树是ACM中经常需要用到的数据结构,熟练掌握map和set的用法很关键,现对其做一个简单的总结. 主要的功能有:插入元素,查找元素,删除,遍历/反向遍历. 插入,删除和查找操作的时间都和树的高 ...
- STL 之 map的用法
Map是STL的一个关联容器,它提供一对一(其中第一个可以称为关键字,每个关键字只能在map中出现一次,第二个可能称为该关键字的值)的数据处理能力,由于这个特性,它完成有可能在我们处理一对一数据的时候 ...
- js数组中foEach和map的用法详解 jq中的$.each和$.map
数组中foEach和map的用法详解 相同点: 1.都是循环遍历数组(仅仅是数组)中的每一项. 2.forEach() 和 map() 里面每一次执行匿名函数都支持3个参数:数组中的当前项value, ...
随机推荐
- linux ad7606 iio
https://wiki.analog.com/resources/tools-software/linux-drivers/iio-adc/ad7606
- Android——Service装取数据
在Service里面装数据,从Activity里面用serviceConnection取数据 xml <?xml version="1.0" encoding="u ...
- Redis管道传输
Redis是一个TCP服务器,并支持请求/响应协议.redis的一个请求完成需要下面的步骤: 客户端发送一个查询到服务器,并从套接字中读取,通常在封闭的方式,对服务器的响应. 服务器处理命令并将响应返 ...
- 【css】清除浮动(clearfix 和 clear)的用法
本文主要是讲解如何在 html 中使用 clearfix 和 clear,针对那些刚开始了解 css 的童鞋.关于 clearfix 和 clear 的样式在这里我就不写了,具体样式点击此处. 下面就 ...
- redis连接超时问题排查
连接池无法获取到连接或获取连接超时redis.clients.jedis.exceptions.JedisConnectionException: Could not get a resource f ...
- LR中错误代号为27796的一个解决方法
问题: 曾经遇到过一个问题,在一次性能测试过程中,使用http协议的多用户向服务器发送请求.设置了持续时间,出现错误为:27796, Failed to connect to server 'ho ...
- Sword protobuf学习四
#include <iostream> #include <string> #include <sys/types.h> /* See NOTES */ #incl ...
- oozie 入门
转自:http://blackproof.iteye.com/blog/1928122 oozie概述:oozie能干什么 oozie格式:怎么用oozie oozie执行:怎么运行oozie ooz ...
- USB2.0学习笔记连载(六):USB2.0硬件设计需要注意事项
笔者在设计USB2.0时找到了一个官方给的硬件设计正确设计指南,其中有些内容还挺nice的.不单单只是USB的设计,其中有些思想可以应用到其他的场合中. 对于USB2.0而言,全速状态下可以达到480 ...
- 101 个 MySQL 的调节和优化的提示
英文原文:101 Tips to MySQL Tuning and Optimization MySQL是一个功能强大的开源数据库.随着越来越多的数据库驱动的应用程序,人们一直在推动MySQL发展到它 ...