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 语言从入门到实战
登录|注册
留言
33
收藏
沉浸
阅读
分享
手机端
回顶部
当前播放: 24 | 共享内存并发机制
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 | 结课测试&结束语
登录 后留言

全部留言(33)

  • 最新
  • 精选
Chris
老师,假如mut.Lock()之前有一段代码,并且还没有执行到这里就出错了,那么defer里面的Unlock就会先执行,这样是不是会出错?

作者回复: 好问题。你完全可以写个程序动手试试。然后,记得把结果分享给大家。

2019-03-27
4
5
码农Kevin亮
为什么老师喜欢把defer函数写在最前面,看起来逻辑怪怪的

作者回复: 1.在设计函数的时候就想清楚收尾工作,释放资源 2.便于排错时,快速确定没有资源/锁等释放问题

2019-11-29
4
Gary
wg.done()是不是放到defer函数里更好?

作者回复: 这个看你的应用场景。

2019-03-19
3
心向无限
线程机制?没有这课啊?

作者回复: 刚才已经联系过平台了,明天平台回补上这一期

2019-03-19
3
hj
... for i := 0; i < 5000; i++ { // 加锁,放在协程的外面 mutex.Lock() go func() { defer func() { mutex.Unlock() }() ...... } } ... 这样也能成功执行,结果是4999。奇怪的点是:在外面lock的,在协程内部可以unlock,也就是说协程可以unlock别人的锁???

作者回复: 其实share memory的锁,更应该看成是共享内容上的锁,每个访问者(协程/线程)在访问共享内容前要先获取这个锁(lock),如果无法锁住就要等待释放,所以才会在每个协程里要先锁住再释放。并不是说释放别人/自己的锁

2019-08-04
1
「ZY」
蔡老师您好 多个协程并发的去修改一个变量 需要用锁或者channel 甚至以下代码 去append一个切片 或者 给map赋值 都不行 会出现 concurrent map writes for i := 0; i < 100; i++ { go func(i int) { slice = append(slice, 1) onlinemap[i] = i }(i) } 那么我的问题来了: 是不是 意味着用GO写服务器的时候 几乎所有的数据都需要加锁或者通过channel来操作了? 比如我想创建一个TCP协议的服务器,n, err := conn.Read(buffer) 读取过来的buffer 不管三七二十一,先放进channel再说是吗?

作者回复: 这个要根据你的需求来看,用chan比较容易做成异步的,共享内存呢比较容易做同步的调用。当然,其实两者都可以构建同步或异步的处理。

2019-03-26
2
1
Geek_c9206f
wg.Done() 是不是可以放在defer里面

作者回复: 可以的

2024-01-17
李圣悦
老师,你好,为啥实力程序运行的时候偶尔会报错?主程序退出,协程会出错? package gorutine_test import ( "testing" ) func TestGroutine(t *testing.T) { for i := 0; i < 10; i++ { go func(i int) { t.Log(i) }(i) } // ime.Sleep(time.Millisecond * 50) }

作者回复: 请提供一些错误信息

2020-11-10
2
Geek_9a021c
这个协程安全的循环跟不用协程的执行效率上有什么区别吗,感觉这里加了lock就变成顺序执行就不是并发了。

作者回复: 看你锁的范围和粒度,让能并行的尽量并行

2020-09-02
Aprelude
go func() { //在defer里面进行释放锁 mut.Lock() defer func() { mut.Unlock() }() counter++ }() 这种写法可以吗

作者回复: 可以

2020-07-12
收起评论