golang语言map全方位介绍

目录
  • 一、map
    • 1.基本介绍
    • 2.声明基本语法
  • 二、map 的使用
    • 2.map[string]map[string]string使用案例
  • 三、map 的增删改查操作
    • 1.map 增加和更新
    • 2.map 删除
    • 3.map 查找
  • 四、map的其他操作
    • 1.map 遍历:
    • 2.map 的长度
    • 3.map 切片
    • 4.map 排序
  • 五、map 使用细节
  • 总结

一、map

1.基本介绍

map 是 key-value 数据结构,又称为字段或者关联数组。类似其它编程语言的集合, 在编程中是经常使用到

2.声明基本语法

var map 变量名 map[keytype]valuetype

  • key 可以是什么类型 :golang 中的 map,的 key 可以是很多种类型,比如 bool, 数字,string, 指针, channel , 还可以是只 包含前面几个类型的 接口, 结构体, 数组
  • 通常 key 为 int 、string     注意: slice, map 还有 function 不可以,因为这几个没法用 == 来判断 
  • valuetype 可以是什么类型: valuetype 的类型和 key 基本一样,这里我就不再赘述了 通常为: 数字(整数,浮点数),string,map,struct

3.声明的举例

map 声明的举例:

  • var a map[string]string
  • var a map[string]int
  • var a map[int]string
  • var a map[string]map[string]string
  • 注意:声明是不会分配内存的,初始化需要 make ,分配内存后才能赋值和使用
package main
import (
	"fmt"
)
func main(){
	//map的声明注意事项
	var a map[string]string
	// 在使用map前,首先要make 分配数据空间。
	a = make(map[string]string,10)
	a["no1"] = "松江"
	a["no2"] = "吴用"
	a["no3"] = "武松"
	a["no1"] = "吴用"
	fmt.Println(a)
}

注意事项:

1.在使用前必须make 否则编译不通过,因为没有空间,所以必须先申请空间

2.上面的代码和结果说明了map中  key值是不可以重复的,(若重复了以最后一个key-value为主)value值可以重复

 make内置函数

二、map 的使用

1.map声明三种方式

方式1:

var a map[string]string
	// 在使用map前,首先要make 分配数据空间。
	a = make(map[string]string,10)
	a["no3"] = "松江"
	a["no1"] = "吴用"
	a["no3"] = "武松"
	a["no2"] = "吴用"
	fmt.Println(a)

方式2:

//第二种方式
	cities := make(map[string]string)
	cities["no1"] = "上海"
	cities["no2"] = "西安"
	cities["no3"] = "天津"
	fmt.Println(cities)

方式3:

//第三种方式
	heroes := map[string]string{
		"no1" : "chengdu",    // 注意不能少了” ,“号
		"no2" : "beijing",
		"no3" : "wuhan",
	}
	fmt.Println(heroes)

2.map[string]map[string]string使用案例

  • 演示一个 key-value 的 value 是 map 的案例
  • 比如:我们要存放 3 个学生信息, 每个学生有 name 和 sex 信息
  • 思路: map[string]map[string]string

三、map 的增删改查操作

1.map 增加和更新

map["key"] = value //如果 key 还没有,就是增加,如果 key 存在就是修改

cities := make(map[string]string)
	cities["no1"] = "上海"
	cities["no2"] = "西安"
	cities["no3"] = "天津"
	fmt.Println(cities)
	//因为no3 这个key值已经存在,所以下面的就是修改,若无就是增加
	cities["no3"] = "天津..."
	fmt.Println(cities)

2.map 删除

delete(map,"key") ,delete 是一个内置函数,如果 key 存在,就删除该 key-value,如果 key 不存在, 不操作,但是也不会报错

//删除演示
	delete(cities,"no1")
	fmt.Println(cities)
	//当delete指定的key不存在时,删除不操作,也不会报错
	delete(cities,"no4")
	fmt.Println(cities)

如果我们要删除 map 的所有 key ,没有一个专门的方法一次删除,可以遍历一下 key, 逐个删除 或者 map = make(...),make 一个新的,让原来的成为垃圾,被 gc 回收 

注意如果要全部删除,两种方式

  • 遍历所有key,逐一删除直接
  • make一个新空间。
//如果希望一次性删除所有  两种方式
	//1.遍历所有key,逐一删除
	//2.直接make一个新空间。
	cities := make(map[string]string)
	fmt.Println(cities)

3.map 查找

//演示map查找
	val , ok :=cities["no2"]
	if ok{
		fmt.Printf("找到了  值为%v",val)
	}else{
		fmt.Printf("没有找到")
	}

说明:如果 cities 这个 map 中存在 "no2" , 那么 findRes 就会返回 true,否则返回 flase

四、map的其他操作

1.map 遍历:

案例演示相对复杂的 map 遍历:该 map 的 value 又是一个 map

说明:map 的遍历使用 for-range 的结构遍历

package main
import (
	"fmt"
)
func main(){
	cities := make(map[string]string)
	cities["no1"] = "上海"
	cities["no2"] = "西安"
	cities["no3"] = "天津"
	for k , v :=range cities{
		fmt.Printf("k=%v v=%v \n",k,v)
	}
}

复杂遍历案例

2.map 的长度

package main
import (
	"fmt"
)
func main(){
	cities := make(map[string]string)
	cities["no1"] = "上海"
	cities["no2"] = "西安"
	cities["no3"] = "天津"
	for k , v :=range cities{
		fmt.Printf("k=%v v=%v \n",k,v)
	}
	fmt.Println(len(cities))   //3
}

3.map 切片

1.基本介绍

切片的数据类型如果是 map,则我们称为 slice of map,map 切片,这样使用则 map 个数就可以动 态变化了。

2.案例

package main
import (
	"fmt"
)
func main(){
	monsters := make([]map[string]string,2)

	if monsters[0] == nil{
		monsters[0] = make(map[string]string,2)
		monsters[0]["name"] = "牛魔王"
		monsters[0]["age"] = "500"
	}
	if monsters[1] == nil{
		monsters[1] = make(map[string]string,2)
		monsters[1]["name"] = "玉兔精"
		monsters[1]["age"] = "400"
	}
	//  这里如果我们继续使用monsters[2] 肯定越界  所以我们需要动态追加
	//这里我们需要使用切片的append函数,可以增加monsters
	//演示:
	newMonsters := map[string]string{
		"name" : "火云邪神",
		"age"  : "200",
	}
	//追加
	monsters = append(monsters,newMonsters)
	fmt.Println(monsters)
}

4.map 排序

1.基本介绍

  • golang 中没有一个专门的方法针对 map 的 key 进行排序
  • golang 中的 map 默认是无序的,注意也不是按照添加的顺序存放的,你每次遍历,得到的输出 可能不一样.
  •  golang 中 map 的排序,是先将 key 进行排序,然后根据 key 值遍

2.案例演示

	map1 := make(map[int]int,100)
	map1[10] = 100
	map1[1] = 13
	map1[4] = 56
	map1[8] = 90
	for k , v :=range map1{
		fmt.Printf("k=%v  v=%v  \n",k , v)  //无序的
	}

没有排序  下来进行排序

//如果按照map的key的顺序进行排序输出
	//1. 先将map的key  放入到切片中
	//2.对切片排序
	//3. 遍历切片,然后按照key来输出map的值
	var keys[]int
	for k , _ := range map1{
		keys = append(keys,k)
	}
	//排序
	sort.Ints(keys)
	fmt.Println(keys)  //输出key值

	for _ , k :=range keys{
		fmt.Printf("map1[%v]=%v \n",k,map1[k])
	}

五、map 使用细节

1) map 是引用类型,遵守引用类型传递的机制,在一个函数接收 map,修改后,会直接修改原来 的 map 

package main
import (
	"fmt"
)
func modify(map2 map[int]int ){
	map2[10] = 900
}

func main(){
	//map是引用类型,遵守引用类型传递机制,在一个函数接受map
	//修改后,会直接修改原来的map
	map1 := make(map[int]int)
	map1[1] = 90
	map1[2] = 88
	map1[10] = 1
	map1[20] = 2

	modify(map1)
	fmt. Println(map1)
}

2)map 的容量达到后,再想 map 增加元素,会自动扩容,并不会发生 panic,也就是说 map 能动 态的增长 键值对(key-value)

3) map 的 value 也经常使用 struct 类型,更适合管理复杂的数据(比前面 value是一个 map 更好)

总结

以上是map的一些介绍 从map的定义到一些增删查改的操作,再到一些使用上的细节。

到此这篇关于golang语言map全方位介绍 的文章就介绍到这了,更多相关golang语言map内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • 快速解决Golang Map 并发读写安全的问题

    一.错误案例 package main import ( "fmt" "time" ) var TestMap map[string]string func init() { TestMap = make(map[string]string, 1) } func main() { for i := 0; i < 1000; i++ { go Write("aaa") go Read("aaa") go Write(&qu

  • Golang通脉之map详情

    目录 1.定义 2.基本使用 3.判断键是否存在 4.map的遍历 5.delete()函数删除map元素 6.指定顺序遍历map 7.map类型的切片 8.value为切片类型的map 9.map是引用类型 Go语言中提供的映射关系容器为map,其内部使用散列表(hash)实现. map 是一种无序的键值对的集合.map 最重要的一点是通过 key 来快速检索数据,key 类似于索引,指向数据的值 map 是一种集合,所以可以像迭代数组和切片那样迭代它.不过,map 是无序的,无法决定它的返回

  • Golang 使用map需要注意的几个点

    1.简介 map 是 Golang 中的方便而强大的内建数据结构,是一个同种类型元素的无序组,元素通过另一类型唯一的键进行索引.其键可以是任何相等性操作符支持的类型, 如整数.浮点数.复数.字符串.指针.接口(只要其动态类型支持相等性判断).结构以及数组. 切片不能用作映射键,因为它们的相等性还未定义.与切片一样,映射也是引用类型. 若将映射传入函数中,并更改了该映射的内容,则此修改对调用者同样可见.未初始化的映射值为 nil. 使用示例如下: package main import "fmt&

  • golang 并发安全Map以及分段锁的实现方法

    涉及概念 并发安全Map 分段锁 sync.Map CAS ( Compare And Swap ) 双检查 分断锁 type SimpleCache struct { mu sync.RWMutex items map[interface{}]*simpleItem } 在日常开发中, 上述这种数据结构肯定不少见,因为golang的原生map是非并发安全的,所以为了保证map的并发安全,最简单的方式就是给map加锁. 之前使用过两个本地内存缓存的开源库, gcache, cache2go,其中

  • Golang 语言map底层实现原理解析

    在开发过程中,map是必不可少的数据结构,在Golang中,使用map或多或少会遇到与其他语言不一样的体验,比如访问不存在的元素会返回其类型的空值.map的大小究竟是多少,为什么会报"cannot take the address of"错误,遍历map的随机性等等. 本文希望通过研究map的底层实现,以解答这些疑惑. 基于Golang 1.8.3 1. 数据结构及内存管理 hashmap的定义位于 src/runtime/hashmap.go 中,首先我们看下hashmap和buck

  • golang语言map全方位介绍

    目录 一.map 1.基本介绍 2.声明基本语法 二.map 的使用 2.map[string]map[string]string使用案例 三.map 的增删改查操作 1.map 增加和更新 2.map 删除 3.map 查找 四.map的其他操作 1.map 遍历: 2.map 的长度 3.map 切片 4.map 排序 五.map 使用细节 总结 一.map 1.基本介绍 map 是 key-value 数据结构,又称为字段或者关联数组.类似其它编程语言的集合, 在编程中是经常使用到 2.声

  • 详解Golang语言HTTP客户端实践

    目录 HTTP客户端封装 测试脚本 测试服务 最近在学习Golang语言,中间遇到一个前辈指点,有一个学习原则:Learning By Doing.跟我之前学习Java的经验高度契合.在前一段时间学习洼坑中挣扎了好几天,差点就忘记这个重要的成功经验. 那么那什么来做练习呢?当然结合当下的工作啦,所以我列了一个路线给自己,那就是从接口测试开始学起来,从功能测试到性能测试,然后掌握基本Server开发技能. 首先,得先把HTTP接口测试常用的几个功能实现了,主要是获取HTTPrequest对象,发送

  • Golang语言如何避免空指针引发的panic详解

    目录 01.介绍 02.结构体指针类型返回值 03.结构体指针类型 value 的 Map 04.defer 延迟调用 05.总结 01.介绍 在 Golang 语言项目开发中,变量操作不当就会触发空指针引发程序 panic.空指针就是未分配内存的指针类型的变量,变量的值是 nil,因为操作空指针会引发 panic,所以我们在程序开发中要特别小心. 02.结构体指针类型返回值 在调用结构体指针类型返回值的函数或方法时,并且需要操作返回值的字段或方法,此时,我们就需要注意触发空指针引发的 pani

  • Golang语言JSON解码函数Unmarshal的使用

    目录 前言 func Unmarshal 普通JSON JSON内嵌普通JSON JSON内嵌数组JSON JSON内嵌具有动态Key的JSON 总结 前言 工作中我们经常会遇到解码JSON格式的数据,本文通过4个示例介绍工作中常用到的四种 JSON格式.在 Golang语言中,通常是使用标准库的encoding/json包中的函数Unmarshal解码JSON格式的数据,下面我们先介绍一下该函数如何使用,再通过4个示例代码来演示一下如何在Golang中解码常见的4种JSON格式的数据. fun

  • 关于golang中map使用的几点注意事项总结(强烈推荐!)

    目录 前言 1 使用 map 记得初始化 2 map 的遍历是无序的 3 map 也可以是二维的 4 获取 map 的 key 最好使用这种方式 5 map 是并发不安全的 ,sync.Map 才是安全的 总结 前言 日常的开发工作中,map 这个数据结构相信大家并不陌生,在 golang 里面,当然也有 map 这种类型 关于 map 的使用,还是有蛮多注意事项的,如果不清楚,这些事项,关键时候可能会踩坑,我们一起来演练一下吧 1 使用 map 记得初始化 写一个 demo 定义一个 map[

  • golang针对map的判断,删除操作示例

    本文实例讲述了golang针对map的判断,删除操作.分享给大家供大家参考,具体如下: map是一种key-value的关系,一般都会使用make来初始化内存,有助于减少后续新增操作的内存分配次数.假如一开始定义了话,但没有用make来初始化,会报错的. 复制代码 代码如下: package main import ( "fmt" ) func main(){ var test =  map[string]string{"姓名":"李四",&qu

  • golang语言编码规范的实现

    本规范旨在为日常Go项目开发提供一个代码的规范指导,方便团队形成一个统一的代码风格,提高代码的可读性,规范性和统一性.本规范将从命名规范,注释规范,代码风格和 Go 语言提供的常用的工具这几个方面做一个说明.该规范参考了 go 语言官方代码的风格制定. 一. 命名规范 命名是代码规范中很重要的一部分,统一的命名规则有利于提高的代码的可读性,好的命名仅仅通过命名就可以获取到足够多的信息. Go在命名时以字母a到Z或a到Z或下划线开头,后面跟着零或更多的字母.下划线和数字(0到9).Go不允许在命名

  • golang映射Map的方法步骤

    map是key-value数据结构,又称为字段或者关联数组.类似其他编程语言的集合 一.基本语法 var 变量名 map[keytype]valuetype // map 使用前要make // map 的key不能重复,重复了,以最后的key-value为准 // map 的key-value 是无序的 var a map[string]string a = make(map[string]string, 10) a["n1"] = "a" a["n2&

  • golang语言如何将interface转为int, string,slice,struct等类型

    在golang中,interface{}允许接纳任意值,int,string,struct,slice等,因此我可以很简单的将值传递到interface{},例如: package main import ( "fmt" ) type User struct{ Name string } func main() { any := User{ Name: "fidding", } test(any) any2 := "fidding" test(a

随机推荐