golang之map的使用声明
1.map的基本介绍
map是key-value数据结构,又称为字段或者关联数组。类似其它编程语言的集合,在编程中是经常使用到的
2.map的声明
1)基本语法
var map 变量名 map[keytype] valuetype
注意:声明是不会分配内存的,初始化需要make,分配内存后才能赋值和使用。
func main() {
var a map[string]string
a = make(map[string]string, 10)
a["no1"] = "allin"
a["no2"] = "alex"
a["no1"] = "egon"
a["no3"] = "sdfegon"
fmt.Println(a)
}
对上面代码的说明
a.map在使用前一定要make
b.map的key是不能重复,如果重复了,则以最后这个key-value为准
c.map的value是可以相同的
d.map的key-value是无序
e.make内置函数数目

map的三种声明方式:
var a map[string]string
a = make(map[string]string, 10)
a["no1"] = "allin"
a["no2"] = "alex"
a["no1"] = "egon"
a["no3"] = "sdfegon"
fmt.Println(a) var b map[string]string
b = make(map[string]string, 10)
b["no1"] = "宋江"
b["no2"] = "吴用"
b["no1"] = "武松"
b["no3"] = "吴用"
fmt.Println(b) heros := map[string]string {
"hero1": "宋江",
"hero2": "lujunyi",
"hero3": "吴用",
}
heros["hero4"] = "林冲"
fmt.Println("heros=", heros)
map删除:
delete(map, "key"),delete是一个内置函数,如果key存在,就删除该key-value,如果key不存在,不操作,但是也不会报错。
如果我们要删除map的所有key,没有一个专门的方法一次删除,可以遍历一下key,逐个删除或者map = kake(...),make一个新的,让原来的成为垃圾,被gc回收。
map查找:
val, ok := studentMap["stu02"]["name"]
if ok {
fmt.Println("aaa", val)
} else {
fmt.Println("bbb")
}
说明:如果student这个mapk中存在“nol", 那么返回true, 否则返回false
map遍历:
for _, v := range studentMap {
//fmt.Println(k, v)
for k1, v1 := range v {
fmt.Println(k1, v1)
}
}
map切片:
切片的数据类型如果是map,则我们称为slice of map,map切片,这样使用则map个数就可以动态变化了。
map排序:
golang中没有一个专门的方法针对map的key进行排序
golang中map的排序,是先将key进行排序,然后根据key值遍历输出即可
map1 := make(map[int]int, 10)
map1[10] = 100
map1[1] = 13
map1[4] = 56
map1[8] = 90
fmt.Println(map1) var keys []int
for k, _ := range map1 {
keys = append(keys, k)
}
sort.Ints(keys)
for _, k := range keys {
fmt.Printf("map1[%v]=%v \n", k, map1[k])
}
map使用细节:
1)map费用类型,遵守引用类型传递的机制,在一个函数接收map,修改后,会直接修改原来的map
2)map的容量达到后,再想map增加元素,会自动扩容,并不会发生panic,也就是说map能动态的增长键值对
3)map的value也经常使用struct类型,更适合管理复杂的数据
golang之map的使用声明的更多相关文章
- Golang中map的三种声明方式和简单实现增删改查
package main import ( "fmt" ) func main() { test3 := map[string]string{ "one": & ...
- 总结golang之map
总结golang之map 2017年04月13日 23:35:53 趁年轻造起来 阅读数:18637 标签: golangmapgo 更多 个人分类: golang 版权声明:本文为博主原创文章, ...
- golang 中 map 转 struct
golang 中 map 转 struct package main import ( "fmt" "github.com/goinggo/mapstructure&qu ...
- golang的map
map--字典 map的基本使用: package main import "fmt" // 先声明 type PersonInfo struct { id string name ...
- Golang:sync.Map
由于map在gorountine 上不是安全的,所以在大量并发读写的时候,会出现错误. 在1.9版的时候golang推出了sync.Map. sync.Map 通过阅读源码我们发现sync.Map是通 ...
- Golang 使用Map构建Set类型的实现方法
前言 本篇主要给大家讲述了如何利用Go语言的语法特性实现Set类型的数据结构,分享出来供大家参考学习,话不多说了,来一起看看详细的介绍吧. 需求 对于Set类型的数据结构,其实本质上跟List没什么多 ...
- golang之map数据类型
先上代码…… package main import "fmt" func testMap() { //两种声明map方式,切记,必须初始化才能用,否则panic //var a ...
- golang 基础 map及工厂函数
Map是一种数据结构,是一个集合,用于存储一系列无序的键值对.它基于键存储的,键就像一个索引一样,这也是Map强大的地方,可以快速快速检索数据,键指向与该键关联的值. 内部实现 Map是基于 散列表 ...
- golang中map原理剖析
1. golang中的map有自己的一套实现原理,其核心是由hmap和bmap两个结构体实现的 2. 初始化map package main func main() { // 初始化一个可容纳10个 ...
随机推荐
- P5346 【XR-1】柯南家族(后缀数组+主席树)
题目 P5346 [XR-1]柯南家族 做法 聪明性是具有传递性的,且排列是固定的 那么先预处理出每个点的名次,用主席树维护\(k\)大值 一眼平衡树,遍历的同时插入\(O(log^2n)\),总时间 ...
- 同一个类里@Cacheable缓存不起作用
问题原因: 注解@Cacheable是使用AOP代理实现的 ,通过创建内部类来代理缓存方法,类内部的方法调用类内部的缓存方法不会走代理,所以就不能正常创建缓存,所以每次都需要去调用数据库. 解决方法: ...
- 获取Linux系统运行时间
uptime |sed 's/^.*up//' |sed 's/users.*//g'|awk '{for(i=1;i<NF;++i) printf $i "\t";prin ...
- linux red hat下安装tomcat的过程
linux下安装tomcat <-----------1.0----------------->:首先需要先去tomcat官网下载linux版本的tomcat的安装包; 我在官网上下载的 ...
- IO流——常用IO流详解
1:字节流 字节流:用于处理以字节为单位的二进制文件(如音乐,图片等) InputStream 是抽象类 它的对应子类FileInputStream可以被实例化 构造方法: FileInputStre ...
- [Ubuntu] 移植Ubuntu16.04根文件系统到嵌入式平台
CPU:RK3288 1.通过 ubuntu cdimage 下载 ubuntu16.04 内核,以下两种方式都可以 在 windows 系统网页中下载 http://cdimage.ubuntu.c ...
- bs4 string与text的区别
用python写爬虫时,BeautifulSoup真是解析html,快速获取所需数据的神器. 这个美味汤使唤起来,屡试不爽. 在用find()方法找到特定的tag后,想获取里面的文本,可以用.text ...
- Qt之模型/视图(委托)
概念 不同于模型 - 视图 - 控制器模式,模型/视图设计不包括用于管理与用户交互的一个完全独立的组件.一般情况,视图负责将模型数据呈现给用户以及处理用户输入.为了输入更加具有灵活性,则由委托来执行交 ...
- 基于golang的websocket通信实现
代码: https://gitee.com/knox_xzk/websocket
- flume 诞生背景 数据同步
flume一开始是cloudlera的项目 当时他们的工程师需要一次次地为客户编写工具 来实现数据的自动化导入