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

【Go语言】Go语言中的字典

Go语言中的字典

字典就是存储键值对映射关系的集合,在Go语言中,需要在声明时指定键和值的类型,此外Go语言中的字典是个无序集合,底层不会按照元素添加顺序维护元素的存储顺序。

如下所示,Go语言中字典的简单示例:

func DictExample() {var tempMap map[string]inttempMap = map[string]int{"one":   1,"two":   2,"three": 3,}k := "two"v, ok := tempMap[k]// ok,如果key存在,则ok为true,否则ok为falseif ok {fmt.Printf("the element of key %q:%d", k, v)} else {fmt.Println("Not found!")}
}

1 字典声明

字典的声明基本上没有多余的元素,例如:

var tempMap map[string]int
// tempMap:声明的字典变量名
// string:字典键的类型
// int:字典值的类型

2 字典初始化

Go语言中,可以先声明再初始化变量,也可以通过 := 将字典的声明和初始化合并为一条语句:

testMap := map[string]int{"one":   1,"two":   2,"three": 3,
}

打印字典testMap,发现其并没有按照存储的顺序进行打印,这是因为Go语言中字典是个无序集合。

在Go语言中,字典的初始化通常要和初始化在一起进行,如果分开了出现编译的报错,如下所示:

var tempMap map[string]int
tempMap["one"] = 1

如果需要初始化一个空的字典,需要使用Go语言内置的 make() 函数:

var tempMap = make(map[string]int)
tempMap["one"] = 1

还可以通过 make() 函数的第二个参数选择是否在创建的时候指定该字典的初始化存储容量(超出会自动扩容):

testMap = make(map[string]int, 100)

3 元素赋值

字典的赋值指定键值对即可,如下所示:

testMap["one"] = 1

注:字典初始化之后才能进行赋值操作,如果仅仅是声明,此时字典的值为 nil, 在nil 上进行操作,编译时会报panic,导致编译不通过。

4 查找元素

Go语言中,通过如下的代码查找特定的键值对:

value, ok := testMap["one"]
if ok {// 字典中存储键"one"对应的值
}
// 如上代码,value是真正返回的键值,ok是是否在字典中找到key对应值的标识,这是一个布尔值,如果查找成功,返回true,否则返回false

5 删除元素

Go语言中,使用delete() 用于删除容器内的元素,也能够用来删除字典元素,如下所示:

delete(testMap,"one")

执行删除时,如果“one”不存在或者字典尚未进行初始化,也不会产生报错。

6 遍历元素

Go语言中,可以像遍历数组一样对字典进行遍历,如下所示:

testMap := map[string]int{"one":1,"two":2,"three":3
}for key,value := range testMap {fmt.Println(key, value)
}

也可以使用匿名变量,只获取字典的值:

for _,value := range testMap {fmt.Println( value)
}

或者只获取字典的键:

for key := range testMap {fmt.Println(key)
}

7 键值对调

testMap := map[string]int{"one":   1,"two":   2,"three": 3,
}newMap := make(map[int]string)for k, v := range testMap {newMap[v] = k
}for k, v := range newMap {fmt.Println(k, v)
}

8 字典排序

Go语言中的字典是个无序集合,如果想要对字典进行排序,可以通过分别为字典的键或值创建切片,然后通过对切片进行排序实现。

按照键进行排序:

testMap := map[string]int{"one":   1,"two":   2,"three": 3,
}
// 创建切片
keys := make([]string, 0)
for key := range testMap {keys = append(keys, key)
}
// 切片排序
sort.Strings(keys)
for _, v := range keys {fmt.Println(v, testMap[v])
}

按照值进行排序:

testMap := map[string]int{"one":   1,"two":   2,"three": 3,
}
// 创建切片
values := make([]int, 0)
for _, value := range testMap {values = append(values, value)
}
// 对字典的值进行排序
sort.Ints(values)
for _, v := range values {fmt.Println(v)
}

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

相关文章:

  • Matlab 机器人工具箱 创建机器人
  • 跨平台指南:在 Windows 和 Linux 上安装 OpenSSL 的完整流程
  • JAVA请求示例获取1688商品详情数据API接口item_get-获得阿里巴巴商品详情(按关键词搜索商品列表)
  • 安卓手机安装termux、kali linux及基本配置
  • Python 实现海康机器人工业相机 MV-CS050-10GC 的实时显示视频流及拍照功能(实时显示视频流同时可以进行拍照)
  • 武器大师——操作符详解(下)
  • 鸿蒙Harmony应用开发—ArkTS声明式开发(通用属性:Popup控制)
  • Python系列(20)—— 排序算法
  • MySQL中json类型的字段
  • 算法学习——GCD与欧拉函数
  • 40. 组合总和 II(力扣LeetCode)
  • Ubuntu上Jenkins自动化部署Gitee上SpringBoot项目
  • 延迟任务基于DeyalQueue
  • Linux 查询端口被占用命令
  • 【c++】string类---标准库中的string类
  • GO语言学习笔记(与Java的比较学习)(五)
  • Sora:探索大型视觉模型的前世今生、技术内核及未来趋势
  • 基于springboot实现图书馆管理系统项目【项目源码+论文说明】计算机毕业设计
  • MATLAB环境下基于高斯滤波器-广义拉普拉斯算子的细胞核自动检测
  • 【探索AI】十一 深度学习之第1周:深度学习概述与基础
  • 【简说八股】Spring事务失效可能是哪些原因?
  • 【语音识别】- CTC损失计算的原理
  • MySQL字符集和比较规则
  • 备忘录模式(Memento Pattern)
  • LeetCode 刷题 [C++] 第121题.买卖股票的最佳时机
  • ORACLE 基础
  • Adobe illustrator CEP插件调试
  • 学会玩游戏,智能究竟从何而来?
  • Unity 常用操作
  • 【计算机网络_应用层】协议定制序列化反序列化