1.Map的定义

map是Go中的内置类型,它将一个值与一个键关联起来。可以使用相应的键检索值。Map 是一种无序的键值对的集合。Map 最重要的一点是通过 key 来快速检索数据,key 类似于索引,指向数据的值

Map 是一种集合,所以我们可以像送代数组和切片那样送代它。不过,Map 是无序的,我们无法决定它的返回顺序,这是因为 Map 是使用 hash 表来实现的,它是引用类型

使用map过程中需要注意的几点:

  • map是无序的,每次打印出来的map都会不一样,它不能通过index获取,而必须通过key获取。map的长度是不固定的,也就是和slice一样,也是一种引用类型。内置的len函数同样适用于map,返回map拥有的key的数量
  • map的key可以是所有可比较的类型,如布尔型、整数型、浮点型、复杂型、字符串型.....也可以键。

2.Map的使用

/**
* @author ly (个人博客:https://www.cnblogs.com/qbbit)
* @date 2023/4/10 20:31
* @tags 喜欢就去努力的争取
*/
package main import "fmt" func main() { /**
方式一:var map1 map[key类型]value类型
*/
var map1 map[int]string /**
方式二:var map2 = make(map[key类型]value类型)
*/
var map2 = make(map[int]string) /**
方式三:var map3 = make[key类型]value类型{k1:v1,k2:v3,......}
*/
var map3 = map[string]int{"Go": 99, "Java": 98, "Python": 97}
map4 := map[int]int{1: 100, 2: 200, 3: 300} fmt.Println(map1)
fmt.Println(map2)
fmt.Println(map3)
fmt.Println(map4) // 如果不初始化 map,那么就会创建一个nil map。nil map不能用来存放键值对
// 这个nil --> 就相当于null
if map1 == nil {
map1 = make(map[int]string)
fmt.Println(map1 == nil)
}
}

map的存储特点

  • 存储的是无序的键值对
  • 键不能重复,并且和value值一一对应的:map的key不能重复,如果重复了,那么新的value会覆盖原来的,程序不会报错

3.map的一些基本操作

map1[1] = "hello"
map1[2] = "world"
map1[3] = "ly"
map1[4] = "王二狗"
map1[5] = "ruby"
map1[6] = "Javascript"
map1[7] = "" fmt.Println(map1)
fmt.Println(map1[3])
fmt.Println(map1[40]) // 1、获取数据,根据key获取对应的value值
// 根据key获取对应的value,如果key存在,获取数值,如果key不存在,获取的是value值类型的零值
val := map1[1]
fmt.Println(val)
// 推荐下面的方式进行获取数据,ok可以进行判断
v1, ok := map1[40]
if ok {
fmt.Println("对应的数值为:", v1)
} else {
fmt.Println("操作的key不存在,获取到的是零值:", v1)
} // 2、添加|修改数据
// key存在修改,key不存在添加
map1[7] = "ly"
fmt.Println(map1) // 3、删除数据
delete(map1, 2)
fmt.Println(map1) // 4、map的长度
fmt.Println("map的长度为:", len(map1))
// fmt.Println("map的容量为:",cap(map1)) // 错误写法

4.map的遍历

/**
map的遍历
使用:for range
数组,切片:index,value
map: key,value
*/
for key, value := range map1 {
fmt.Printf("key:%d , value:%s \n", key, value)
} for _, value := range map1 {
fmt.Println("value:", value)
} // 创建一个切片
keys := make([]int, 0, len(map1))
fmt.Println("keys:", keys) // 遍历map
for k, _ := range map1 {
keys = append(keys, k)
}
fmt.Println(keys) // 排序
sort.Ints(keys)
fmt.Println(keys) // 这样就可以顺序的拿到map中的值了
for _, key := range keys {
fmt.Println(key, map1[key])
} // 字符串的排序
s1 := []string{"App", "windows", "Orange", "abc", "acd", "acc", "宝宝"}
fmt.Println(s1)
sort.Strings(s1)
fmt.Println(s1)

5.map和slice的使用

// map和slice结合使用
mapA := make(map[string]string)
mapA["name"] = "zs"
mapA["age"] = "18"
mapA["address"] = "湖北武汉" mapB := make(map[string]string)
mapB["name"] = "ly"
mapB["age"] = "20"
mapB["address"] = "湖北黄石" sl := make([]map[string]string, 0, 2)
sl = append(sl, mapA)
sl = append(sl, mapB)
fmt.Println(sl) for index, m := range sl {
fmt.Println(index, m["name"], m["age"], m["address"])
}

6.map是引用类型

// map是引用类型
mapC := make(map[string]float64)
mapD := make(map[int]int64)
fmt.Printf("%T\n", mapC)
fmt.Printf("%T\n", mapD) mapE := make(map[string]map[int]string)
fmt.Printf("%T\n", mapE) m1 := make(map[int]string)
m1[1] = "a"
m1[2] = "b" m2 := make(map[int]string)
m2[1] = "ly"
m2[2] = "bao" mapE["A"] = m1
mapE["B"] = m2 fmt.Println(mapE) // 验证map是引用类型
mapF := mapE fmt.Println(mapE)
fmt.Println(mapF) m3 := map[int]string{1: "zs", 2: "包"}
mapF["A"] = m3 // 验证
fmt.Println(mapE)
fmt.Println(mapF)

14、Map的更多相关文章

  1. go语言的 数组、slice、map使用(转)

    golang群 点击加入 go语言的 数组.slice.map使用, 由于网上有很好的说明, 不需要再写了,请看这几篇: Go语言中的 Array, Slice和 Map 深入学习golang五篇,以 ...

  2. Python特殊语法--filter、map、reduce、lambda

    一.filter(function, sequence) 对sequence中的item依次执行function(item),将执行结果为True的item组成一个List/String/Tuple( ...

  3. Python特殊语法:filter、map、reduce、lambda [转]

    Python特殊语法:filter.map.reduce.lambda [转] python内置了一些非常有趣但非常有用的函数,充分体现了Python的语言魅力! filter(function, s ...

  4. Java 集合系列14之 Map总结(HashMap, Hashtable, TreeMap, WeakHashMap等使用场景)

    概要 学完了Map的全部内容,我们再回头开开Map的框架图. 本章内容包括:第1部分 Map概括第2部分 HashMap和Hashtable异同第3部分 HashMap和WeakHashMap异同 转 ...

  5. Java集合的Stack、Queue、Map的遍历

    Java集合的Stack.Queue.Map的遍历   在集合操作中,常常离不开对集合的遍历,对集合遍历一般来说一个foreach就搞定了,但是,对于Stack.Queue.Map类型的遍历,还是有一 ...

  6. java中将list、map对象写入文件

    链接地址:http://blog.sina.com.cn/s/blog_4a4f9fb50101p6jv.html     推荐:凤爪女瓜子男怪象该谁反思伦敦房价为什么持续暴涨 × wvqusrtg个 ...

  7. STL学习:STL库vector、string、set、map用法

    本文仅介绍了如何使用它们常用的方法. vector 1.可随机访问,可在尾部插入元素:2.内存自动管理:3.头文件#include <vector> 1.创建vector对象 一维: (1 ...

  8. ReactiveCocoa源码解析(五) SignalProtocol的observe()、Map、Filter延展实现

    上篇博客我们对Signal的基本实现以及Signal的面向协议扩展进行了介绍, 详细内容请移步于<Signal中的静态属性静态方法以及面向协议扩展>.并且聊了Signal的所有的g功能扩展 ...

  9. ReactiveSwift源码解析(五) SignalProtocol的observe()、Map、Filter延展实现

    上篇博客我们对Signal的基本实现以及Signal的面向协议扩展进行了介绍, 详细内容请移步于<Signal中的静态属性静态方法以及面向协议扩展>.并且聊了Signal的所有的g功能扩展 ...

  10. JS中集合对象(Array、Map、Set)及类数组对象的使用与对比

    原文地址 在使用js编程的时候,常常会用到集合对象,集合对象其实是一种泛型,在js中没有明确的规定其内元素的类型,但在强类型语言譬如Java中泛型强制要求指定类型. ES6引入了iterable类型, ...

随机推荐

  1. AI绘画:Stable Diffusion 终极炼丹宝典:从入门到精通

    本文收集于教程合集:AIGC从入门到精通教程汇总 我是小梦,以浅显易懂的方式,与大家分享那些实实在在可行之宝藏. 历经耗时数十个小时,总算将这份Stable Diffusion的使用教程整理妥当. 从 ...

  2. 详解 canal 同步 MySQL 增量数据到 ES

    canal 是阿里知名的开源项目,主要用途是基于 MySQL 数据库增量日志解析,提供增量数据订阅和消费. 这篇文章,我们手把手向同学们展示使用 canal 将 MySQL 增量数据同步到 ES . ...

  3. 基于velero及minio实现etcd数据备份与恢复

    1.Velero简介 Velero 是vmware开源的一个云原生的灾难恢复和迁移工具,它本身也是开源的,采用Go语言编写,可以安全的备份.恢复和迁移Kubernetes集群资源数据:官网https: ...

  4. 《Python魔法大冒险》008 石像怪的挑战:运算符之旅

    小鱼和魔法师继续深入魔法森林.不久,他们来到了一个巨大的魔法石圈旁边.石圈中心有一个闪闪发光的魔法水晶,周围则是一些神秘的符号.但令人意外的是,水晶的旁边还有一个巨大的石像怪,它的眼睛散发着红色的光芒 ...

  5. 通过 Haproxy 实现 ss 负载均衡

    介绍 缺点:所有的SS的加密方式和密码必须一致 介绍:HAProxy是一个使用C语言编写的自由及开放原始码软件,其提供高可用性.负载均衡,以及基于TCP和HTTP的应用程序代理. 安装Haproxy ...

  6. Solution -「CF 1303G」Sum of Prefix Sums

    Description Link. 对于一棵树,选出一条链 \((u,v)\),把链上结点从 \(u\) 到 \(v\) 放成一个 长度 \(l\) 的数组,使得 \(\sum_{i=1}^{l}\s ...

  7. Springboot+Mybatisplus+ClickHouse集成

    核心依赖引入 <dependency> <groupId>ru.yandex.clickhouse</groupId> <artifactId>clic ...

  8. Unexpected keys "@@dva", "user" found in preloadedState argument passed to createStore. Expected to find one of the known reducer keys instead: "router", "loading". Unexpected keys will be ignored.

    Please use `require("history").DOMUtils` instead of `require("history/DOMUtils") ...

  9. Java21上手体验-分代ZGC和虚拟线程

    一.导语 几天前Oracle刚刚发布了Java21, 由于这是最新的LTS版本,引起了大家的关注. 我也第一时间在个人项目中进行了升级体验. 一探究竟,和大家分享. 二.Java21更新内容介绍 官方 ...

  10. 深入理解 Netty FastThreadLocal

    作者:vivo 互联网服务器团队- Jiang Zhu 本文以线上诡异问题为切入点,通过对比JDK ThreadLocal和Netty FastThreadLocal实现逻辑以及优缺点,并深入解读源码 ...