当前位置: 首页 > news >正文

go语言基础 -- map的定义与使用

map的定义与使用

  • map声明基础语法
    • map的基本使用
    • map的遍历
    • map切片
    • map排序

map声明基础语法

// map的声明
var xxx_map map[key_type]value_type

map的key可以是基本数据类型,channel,接口,结构体,数组,但不能是slice,map,function,因为他们不能用==判断,声明时不会开辟内存,分配内存需要用到make,make分配内存之后才能使用

xxx_map = make(map[key_type]value_type, size)

make时通过size指定分配可存储的key-value个数,需要注意的是,go里面的map是无序的,但同样的,key也不能重复,重复时保留最后一个存储的数据
除了上面的声明后再make的方式外,还有下面两种方式:

citys := make(map[string]string) // 大小不写的话默认,同时也会自动增长
citys["beijing"] = "bj"
name_map := map[string]string {"name1" : "lzs","name2" : "zp", //这里需要有逗号
}

map类型虽然不能做key,但可以做为value,用法如下:

student_age := make(map[string]map[string]int, 3)
student_age["stu1"] = make(map[string]int, 5) // 别忘了内层map也需要先make再使用

map的基本使用

var citys = make(map[string]string, 3)
citys["city1"] = "beijing"
citys["city2"] = "shanghai"
// delete是内置函数,不用引包,若待删除的key不存在时,删除操作不会被执行
delete(citys, "citys1")
// 查找某个key是否存在,若存在,is_find为true,否则为false
val, is_find := citys["city3"]

如果我们要删除整个map,要么就对map整个遍历,之后再删除,要么就赋值为新map,让原map指向空间被gc回收
map的长度也能用len()来统计

map_len := len(citys)

map的遍历

map只能用for range的方式遍历

for k, v := range citys {// ...
}

map切片

如果切片的数据类型是map,则称作map切片,map切片的好处是可以动态增长,理解起来可以看错c++中的vecrtor存了个map。

// 声明一个map切片
var slice1 []map[string]string
// 使用时需要先给切片分配空间,再给map分配空间
slice1 = make([]map[string]string, 1)
slice1[0] = make(map[string]string)

map排序

由于map是无序的,如果想要对map里面的内容按key排序,需要对key先排序,再按key的顺序取value值

http://www.lryc.cn/news/308269.html

相关文章:

  • 讯方·智汇云校第五期名师班火热报名中!
  • 为什么企业需要使用云电子邮箱?
  • [DEBUG] spring boot-如何处理链接中的空格等特殊字符
  • 通过配置数据库事件(Event)来实现定时导出 MySQL 数据库
  • 基于x86架构的OpenHarmony应用生态挑战赛等你来战!
  • LeetCode每日一题2673. Make Costs of Paths Equal in a Binary Tree
  • 贝叶斯分类器
  • 游戏服务之会话管理
  • LeetCode20 有效的括号
  • sql实战_基于某推荐比值问题
  • 协议的概念+本质+作用+最终表现形式,网络问题(技术+应用+解决的协议+存在原因),主机的对称性
  • iOS中卡顿产生的主要原因及优化思路
  • spring boot集成Elasticsearch 7.16.3
  • HTML5+CSS3小实例:环绕小球弹性loading动画
  • SpringBoot 自定义注解实现操作日志记录
  • ubuntu常见配置
  • electron+vue3全家桶+vite项目搭建【27】封装窗口工具类【1】雏形
  • 从模型到复合AI系统的转变
  • 将仓库A中的部分提交迁移到仓库B中
  • 信息安全技术基础
  • flask知识--01
  • 软考52-上午题-【数据库】-关系模式2
  • devc++跑酷小游戏3.5.0
  • Redisson限流算法
  • GPT与MBR:硬盘分区表格式的革新与区别
  • 机器学习-1
  • Stream流详解
  • javaweb学习(day05-TomCat)
  • 【Unity】构建简单实用的年份选择器(简单原理示范)
  • LeetCode 2120.执行所有后缀指令