golang中的map
1. 声明与初始化
// map的声明与初始化
userInfo := map[string]string{"name": "马亚南", "age": "18"}
fmt.Println(userInfo)
fmt.Println(userInfo["name"]) // 马亚南
userInfo["age"] = "28"
fmt.Println(userInfo)
userInfo["email"] = "wupeiqi@live.com"
fmt.Println(userInfo) // 声明
var userInfo2 = map[string]string{}
userInfo2["age"] = "88"
fmt.Println(userInfo2) // make创建map
data := make(map[int]int)
data[100] = 998
data[200] = 999
fmt.Println(data) // 只有声明,nil ,无法设置
var row map[int]int // 这种声明用于整体的赋值
//row["name"] = 666 // 错误的
row = data
fmt.Println(row) // new创建map, nil
// 这种声明也是用于整体的赋值,但是赋值的是map的指针类型
value := new(map[int]int)
value = &data
fmt.Println(*value)
// 注意:键不重复、键必须可哈希(int/bool/float/string/array),map是无序的
v1 := make(map[[2]int]float32)
v1[[2]int{11, 22}] = 3.15
v1[[2]int{33, 44}] = 2.88
fmt.Println(v1)
2. map的长度和容量
// 1. 长度和容量
data := map[string]string{"n1": "武沛齐", "n2": "alex"}
fmt.Println(len(data)) // 2. make创建map并且指定了容量cap
// 根据参数值10,计算出合适的容量
// 一个map中会包含很多的桶,每个桶中可以存放8个键值对
info := make(map[string]string, 10)
info["n1"] = "武沛齐"
info["n2"] = "alex" fmt.Println(len(info))
//fmt.Println(cap(info)) 报错
3. map中value的嵌套用法
// value中的嵌套
// map的值可以使任意类型
// 值是数组类型
v4 := make(map[string][]int)
v4["n1"] = []int{11, 22, 33, 44, 55}
v4["n2"] = []int{11, 22}
fmt.Println(v4) // 值是map类型
v5 := make(map[string]map[int]int)
v5["n1"] = map[int]int{1: 999, 2: 888}
v5["n2"] = map[int]int{11: 99, 22: 88}
fmt.Println(v5) // 值是数组类型,值得数组中存储的是map类型
v7 := make(map[string][2]map[string]string)
v7["n11"] = [2]map[string]string{{"name": "马亚南"}, {"name": "马馨彤"}}
v7["n12"] = [2]map[string]string{{"age": "18"}, {"age": "28"}}
fmt.Println(v7)
4. map的增删改查
data := map[string]string{"n1": "武沛齐", "n2": "alex"}
// 增加
data["n3"] = "eric"
// 修改
data["n1"] = "武沛齐2"
// 删除
delete(data, "n2")
// 查看
fmt.Println(data["n1"])
// 循环查看键值对
for key, value := range data {
fmt.Println(key, value)
}
// 循环查看键
for key := range data {
fmt.Println(key)
}
// 循环查看值
for _, value := range data {
fmt.Println(value)
}
5. map中键的嵌套
// 键不重复 & 键必须可哈希
data1 := make(map[int]int)
data2 := make(map[bool]int)
data3 := make(map[float32]int)
data4 := make(map[string]int)
data5 := make(map[[2]int]int)
//data6 := make(map[[]int]int) // 错误, 不可哈希
//data7 := make(map[map[int]int]int) // 错误, 不可哈希
//data8 := make(map[ [2]map[string]string ]int) // 错误, 虽然键是数组,但是数组里面的值是map,所以不可哈希
6. map中变量赋值
// 变量赋值,
map1 := map[string]string{"n1": "武沛齐", "n2": "alex"}
map2 := map1 map1["n1"] = "哈哈"
fmt.Println(map1)
fmt.Println(map2)
特别提醒:map中无论是否存在扩容,都指向同一个地址
golang中的map的更多相关文章
- golang中,map作为函数参数是如何传递的
当你声明一个map的时候: m := make(map[int]int) 编译器会调用 runtime.makemap: // makemap implements a Go map creation ...
- Golang中的Map(集合)
Map 是一种无序的键值对的集合.Map 最重要的一点是通过 key 来快速检索数据,key 类似于索引,指向数据的值. Map 是一种集合,所以我们可以像迭代数组和切片那样迭代它.不过,Map 是无 ...
- Golang 中使用多维 map
http://tnt.wicast.tk/2015/11/02/golang-multiple-dimension-map/ Golang 的 XML/JSON 解析库乍看使用起来很方便,只要构造一样 ...
- golang中map原理剖析
1. golang中的map有自己的一套实现原理,其核心是由hmap和bmap两个结构体实现的 2. 初始化map package main func main() { // 初始化一个可容纳10个 ...
- 说说不知道的Golang中参数传递
本文由云+社区发表 导言 几乎每一个C++开发人员,都被面试过有关于函数参数是值传递还是引用传递的问题,其实不止于C++,任何一个语言中,我们都需要关心函数在参数传递时的行为.在golang中存在着m ...
- Golang基础教程——map使用篇
本文始发于个人公众号:TechFlow,原创不易,求个关注 今天是golang专题的第7篇文章,我们来聊聊golang当中map的用法. map这个数据结构我们经常使用,存储的是key-value的键 ...
- Go_14:GoLang中 json、map、struct 之间的相互转化
1. golang 中 json 转 struct <1. 使用 json.Unmarshal 时,结构体的每一项必须是导出项(import field).也就是说结构体的 key 对应的首字母 ...
- GoLang中 json、map、struct 之间的相互转化
1. golang 中 json 转 struct <1. 使用 json.Unmarshal 时,结构体的每一项必须是导出项(import field).也就是说结构体的 key 对应的首字母 ...
- golang 中 map 转 struct
golang 中 map 转 struct package main import ( "fmt" "github.com/goinggo/mapstructure&qu ...
随机推荐
- 优化MySQL占用内存过高
打开mysql 的配置文件 my.cnf 查找方式:https://www.cnblogs.com/pxblog/p/13701211.html 在[mysqld]后面修改或添加 # The max ...
- CMake判断操作系统和编译器
判断操作系统 IF (CMAKE_SYSTEM_NAME MATCHES "Linux") ELSEIF (CMAKE_SYSTEM_NAME MATCHES "Wind ...
- 【LeetCode】525. Contiguous Array 解题报告(Python & C++)
作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 累积和 日期 题目地址:https://leetco ...
- 1114 - Easily Readable
1114 - Easily Readable PDF (English) Statistics Forum Time Limit: 2 second(s) Memory Limit: 32 MB ...
- 从头造轮子:python3 asyncio 之 run(2)
前言 书接上文,本文造第二个轮子,也是asyncio包里面非常常用的一个函数run 一.知识准备 ● 相对于run_until_complete,改动并不大,就是将入口函数重新封装了一下,基础知识主要 ...
- Java EE数据持久化框架 • 【第3章 MyBatis高级映射】
全部章节 >>>> 本章目录 3.1 一对一映射 3.1.1 自动化一对一映射 3.1.2 标签配置一对一映射 3.1.3 标签配置一对一映射 3.1.4 实践练习 3.2 ...
- 编写Java程序,实现一个简单的echo程序(网络编程TCP实践练习)
首先启动服务端,客户端通过TCP的三次握手与服务端建立连接: 然后,客户端发送一段字符串,服务端收到字符串后,原封不动的发回给客户端. ECHO 程序是网络编程通信交互的一个经典案例,称为回应程序,即 ...
- Android开发案例 点击按钮出现 简易的消息提示框
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android=&quo ...
- CSS基础-4 定位
CSS定位和浮动 css定位:改变页面的位置 定位机制有以下三种 普通流 浮动 绝对布局 定位的属性: position:把元素放在一个静态的.相对的.绝对的.或固定的位置中 top ...
- 树形DP总结基础
概念 应用 例题 最大独立子集 没有上司的晚会 题目描述 分析 树的重心 题目描述 分析 树的直径 概念 题目描述 分析 概念 给定一棵有N个节点的树(通常是无根树,也就是有N-1条无向边),我们可以 ...