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
收藏
沉浸
阅读
分享
手机端
回顶部
当前播放: 23 | 协程机制
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)

  • 最新
  • 精选
Eden
初学语言,使用中文解释,方便理解 ``` // M -- System Thread 「系统线程」 // P -- Processor 「Go 语言的协程处理器」 // G -- Goroutine 「协程」 func TestGroutine(t *testing.T) { for i := 0; i < 10; i++ { // fmt.Println(i) go func(par int) { // 使用go创建协程,但是需要注意的是:协程函数的par作为参数是外部i的数据拷贝 fmt.Println(par) }(i) } time.Sleep(time.Millisecond * 50) } ```

作者回复: 非常感谢!

2019-06-05
2
11
序灬曲
老师,我的代码如下,但是每次运行结果都不准确 var wg sync.WaitGroup func TestIncreaseCounter(t *testing.T){ counter := 0 for i:=0;i<1000 ;i++ { wg.Add(1) go func() { counter++ wg.Done() }() } wg.Wait() t.Log("Counter = " + strconv.Itoa(counter)) } 找了半天错误,我还是找不到为什么错误,请老师指导

作者回复: 这个是因为counter不是线程安全的,要用sync.Mutex的lock来同步,参考视频

2019-03-21
2
7
小楠zz
老师你好,我想问下go的协程跟python的协程一样吗,不一样的话哪里不一样?

作者回复: go的协程本质是系统的线程调用,而Python中的协程是eventloop模型实现,所以虽然都叫协程,但并不是一个东西

2019-05-23
3
6
静远投基
老师!请教问题:我一直以为go调度不会中断持续运行中的gorouting,可下面两个例子的结果让我凌乱了 package main import ( "log" "runtime" ) func main(){ runtime.GOMAXPROCS(1) for{ go func() { log.Println("0") }() log.Println("1") } } 这样会0,1交替输出,而 package main import ( "log" "runtime" ) func main(){ runtime.GOMAXPROCS(1) go func() { log.Println("0") }() for{ log.Println("1") } } 只会输出1,请问gorouting 是怎样调度的?

作者回复: Goroutine的调度是这样的 启动的时候,会专门创建一个线程sysmon,用来监控和管理,在内部是一个循环: 1.     记录所有P的G任务计数schedtick,(schedtick会在每执行一个G任务后递增) 2.     如果检查到 schedtick一直没有递增,说明这个P一直在执行同一个G任务,如果超过一定的时间,就在这个G任务的栈信息里面加一个标记 3.     然后这个G任务在执行的时候,如果遇到非内联函数调用,就会检查一次这个标记,然后中断自己,把自己加到队列末尾,执行下一个G 你可以试试下面这个程序,多运行一会,你就会看到切换 func doSomething(i int) { fmt.Print(i) } func main() { runtime.GOMAXPROCS(1) go func() { for { doSomething(0) } }() for { doSomething(1) } }

2019-05-13
3
3
Geek_d586af
package coroutines import ( "fmt" "testing" ) func TestConoutines(t *testing.T) { for i:=1;i<10;i++ { go func() { fmt.Println(i) }() } } 运行后有时候并不都是10 === RUN TestConoutines 8 10 10 10 10 10 10 10 --- PASS: TestConoutines (0.00s) 10 PASS 这是什么情况呢?老师在不?能解答一下不

作者回复: 代码需要改成下面这样,原因我在讲座中有介绍 func TestConoutines(t *testing.T) { for i:=1;i<10;i++ { go func(j int) { fmt.Println(j) }(i) } }

2021-01-08
1
贾敏
这里的 `Processor` 是指 逻辑处理器么?每个进程是不是只有一个逻辑处理器

作者回复: 对的是逻辑上,可以通过GOMAXPROCS定义

2020-04-16
1
Jason
老师,我有个疑问,既然协程的执行器会去切出阻塞的协程,为什么还需要调度器去把阻塞执行器中的任务均衡到空闲的执行器上呢?

作者回复: 这里不是很方便输入很多文字。推荐可以看看这两篇 https://m.imooc.com/mip/article/42071 https://studygolang.com/articles/11862?open_source=weibo_search

2019-04-19
1
王云峰
老师跟我很像啊 都不善于沟通一心搞技术

作者回复: 哈哈,技术人通病

2023-12-24
Calvin
for i := 0; i < 10; i++ { go func() { fmt.Println(i) }() time.Sleep(time.Millisecond * 50) } 老师,按你的代码来试,我的这段代码为什么可以正常输出 0-9 啊(不是像视频中那样都是 10)? 我使用的 Go 版本是 1.16.5。

作者回复: 你可以调整一下sleep的时间试试

2021-06-26
3
Jabir_Zhang
老师,您好,go func(par int) { fmt.Println(par) }(i) 这最后的括号里面传参是干什么的

作者回复: 是那个par的值,作为参数传人

2019-06-14
2
收起评论