Go 语言从入门到实战
蔡超
Mobvista 技术副总裁兼首席架构师,前亚马逊(中国)首席软件架构师
48919 人已学习
新⼈⾸单¥59
课程目录
已完结/共 55 讲
第一章:Go语言简介 (4讲)
第二章:基本程序结构 (4讲)
第三章:常用集合 (3讲)
第四章:字符串 (1讲)
时长 16:47
第五章:函数 (2讲)
第六章:面向对象编程 (4讲)
第七章:编写好的错误处理 (2讲)
第八章:包和依赖管理 (2讲)
第九章:并发编程 (7讲)
第十章:典型并发任务 (5讲)
第十一章:测试 (3讲)
时长 11:48
时长 07:12
时长 06:15
第十二章:反射和Unsafe (3讲)
时长 08:18
时长 08:03
第十三章:常见架构模式的实现 (2讲)
第十四章:常见任务 (4讲)
时长 04:27
时长 05:14
第十五章:性能调优 (4讲)
第十六章:高可用性服务设计 (5讲)
Go 语言从入门到实战
登录|注册
留言
24
收藏
沉浸
阅读
分享
手机端
回顶部
当前播放: 10 | Map声明、元素访问及遍历
00:00 / 00:00
高清
  • 高清
1.0x
  • 2.0x
  • 1.5x
  • 1.25x
  • 1.0x
  • 0.75x
  • 0.5x
网页全屏
全屏
00:00
付费课程,可试看
01 | Go语言课程介绍
02 | 内容综述
03 | Go语言简介:历史背景、发展现状及语言特性
04 | 编写第一个Go程序
05 | 变量、常量以及与其他语言的差异
06 | 数据类型
07 | 运算符
08 | 条件和循环
09 | 数组和切片
10 | Map声明、元素访问及遍历
11 | Map与工厂模式,在Go语言中实现Set
12 | 字符串
13 | Go语言的函数
14 | 可变参数和defer
15 | 行为的定义和实现
16 | Go语言的相关接口
17 | 扩展与复用
18 | 不一样的接口类型,一样的多态
19 | 编写好的错误处理
20 | panic和recover
21 | 构建可复用的模块(包)
22 | 依赖管理
23 | 协程机制
24 | 共享内存并发机制
25 | CSP并发机制
26 | 多路选择和超时
27 | channel的关闭和广播
28 | 任务的取消
29 | Context与任务取消
30 | 只运行一次
31 | 仅需任意任务完成
32 | 所有任务完成
33 | 对象池
34 | sync.pool对象缓存
35 | 单元测试
36 | Benchmark
37 | BDD
38 | 反射编程
39 | 万能程序
40 | 不安全编程
41 | 实现pipe-filter framework
42 | 实现micro-kernel framework
43 | 内置JSON解析
44 | easyjson
45 | HTTP服务
46 | 构建RESTful服务
47 | 性能分析工具
48 | 性能调优示例
49 | 别让性能被锁住
50 | GC友好的代码
51 | 高效字符串连接
52 | 面向错误的设计
53 | 面向恢复的设计
54 | Chaos Engineering
55 | 结课测试&结束语
登录 后留言

全部留言(24)

  • 最新
  • 精选
辉仔lovers
老师:您好,请教个问题,make方式来创建map的时候传递了第二个参数capcity的作用是什么,是为了当map的长度超过capcity的时候自动扩容吗?其他方式初始化map的时候,是不是底层默认了一个初始容量呢?map的底层数据结构是类似于java中hashmap的哈希表吗?

作者回复: capacity是设置初始化容量,map会自动扩容,但扩容会导致内存分配和数据复制,所以如果能够初始化到比较适合的capacity,可以提高性能。

2019-03-08
2
9
行军伙夫
老师你好,我初始化了map[string]int { "1": 1, "2": 4, "3": 9, "4": 16 },当我用range进行遍历的时候,输出的结果并没有按照 1 1 , 2 4, 3 9, 4 16的顺序进行输出,我想问问range遍历有自定义排序嘛

作者回复: map的底成采用hash表机制,不是有序的

2019-03-18
4
6
大王叫我来巡山
非常感谢老师,作为软件开发行业的老鸟,写go语言有段时间,依然能有所收获,学习就是个不断交流的过程,我们在每一次交流中都能收获心得体会,对学习常怀敬畏之心,对同行怀谦卑之心。

作者回复: 谢谢你的鼓励!让我们大家持续学习!

2019-03-13
5
码农Kevin亮
请问老师,既然map的取值是返回两个值,那么为什么打印语句来打印map取值时只会输出值,而不会把ok的布尔值也输出了呢?

作者回复: fmt的输出在默认情况下是调用类型的String方法的,这样就是说map的String方法里没有输出ok这个值

2019-11-26
4
蒙晓蒙
func TestMapVal(t *testing.T) { var m = map[string]int {"one":1,"two":2,"three":3,"four":4,"five":5} for k,v:=range m { t.Log(k,v) } } 运行后输出值为: Map_test.go:25: four 4 Map_test.go:25: five 5 Map_test.go:25: one 1 Map_test.go:25: two 2 想问下为什么是这种输出顺序

作者回复: map底成是通过hash来指定存储位置的,不是有序的

2019-03-18
2
郭星
func TestDeclareInit(t *testing.T) { // 只声明 var m1 map[int]int // 初始化值为nil,但支持访问 t.Log(m1) t.Log(m1[1]) // 输出了0 } m1为nil 为什么 m1[1] 不会报错呢?

作者回复: 是的,Go语言中就是返回该类型的默认值,如果要判断是否存在该元素,要用一以下方式: v, isExisting := m1[1]

2020-07-31
1
    
老是情不自禁 想加个 ;

作者回复: 哈哈,java上脑

2022-11-07
2
Geek_427d0c
go的检查map key是否存在相当繁琐啊,比如在java里,可以一行实现: map.get("a") != null? map.get("a"): somethingElse; 在go得用多行实现?

作者回复: 一般这么写 if a, ok := MyMap["111"]; !ok{ // The key doesn't exist. }

2020-09-27
2
阿鹏
因为值是int类型,所以默认是0,如果换成string类型,默认就是空字符串了
2019-03-07
3
16
碧雪天虹
看到一些同学说排序, 我也尝试了一下, 步骤上就是把key都存储到slice里面, 然后给key排序, 在遍历key并打印值. func TestSortByKey(t *testing.T) { m1 := map[string]int{"aa": 1, "zz": 2, "bb": 3, "yy": 4, "cc": 5, "xx": 6} s1 := make([]string, 0, len(m1)) for k, _ := range m1 { s1 = append(s1, k) } sort.Strings(s1) for _, k := range s1 { t.Log(k, m1[k]) } }
2019-10-17
2
收起评论