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 语言从入门到实战
登录|注册
留言
16
收藏
沉浸
阅读
分享
手机端
回顶部
当前播放: 42 | 实现micro-kernel framework
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 | 结课测试&结束语
登录 后留言

全部留言(16)

  • 最新
  • 精选
小寞子。(≥3≤)
mutex.Lock() 应该在 err = collector.Start(ctx)之前吧 不然用啥锁。。

作者回复: 这里的锁实际要保护的是 errs.CollectorErrors的读写。 为了提高程序的性能,锁的范围要尽量小

2021-01-13
3
林润娥是我女朋友
老师什么时候出门架构师的课一定支持,哈哈哈

作者回复: 谢谢你的支持.

2021-07-20
2
5423
请问这个章节讲的是什么呢?没有太懂?是自己的程序套什么‘公式’吗?应该这样理解吗?概念上的?

作者回复: 是我们的软件设计,有一些可以参考的模式。

2020-12-17
2
Coder4
老师。微内核模式,会有对象循环引用的问题么?

作者回复: 依赖是通过接口的,不会有这个问题

2019-04-10
1
圆滚滚
为什么RegisterCollector的入参中类型是Collector而不是*Collector, 传入Collector类型的变量,会造成对象拷贝么?

作者回复: Collect是接口

2021-11-24
森美
老师,我看这个章节的源码里面,在测试代码agent_test.go这里,用于测试的DemoCollector有个属性是上下文agtCtx, 但观察测试代码的逻辑,我发现好像并没有哪里使用到这个上下文agtCtx。像Start方法里面,如果检测到上下文有发出cancel通知,那就结束任务,只不过这里的上下文是Agent的上下文,不是DemoCollector的上下文。

作者回复: 看以下两端代码: func (agt *Agent) Start() error { if agt.state != Waiting { return WrongStateError } agt.state = Running agt.ctx, agt.cancel = context.WithCancel(context.Background()) go agt.EventProcessGroutine() return agt.startCollectors() } func (agt *Agent) startCollectors() error { var err error var errs CollectorsError var mutex sync.Mutex for name, collector := range agt.collectors { go func(name string, collector Collector, ctx context.Context) { defer func() { mutex.Unlock() }() err = collector.Start(ctx) mutex.Lock() if err != nil { errs.CollectorErrors = append(errs.CollectorErrors, errors.New(name+":"+err.Error())) } }(name, collector, agt.ctx) } if len(errs.CollectorErrors) == 0 { return nil } return errs }

2021-01-10
3
请问下这里为什么要用一个stopChan来给stop()传递停止的指令呢?stop()里面是否可以直接用<-c.evtReceiver.ctx.Done()?

作者回复: 那样是可以的。但是程序就无法管理这个停止过程中Agent产生的错误了

2020-04-30
forrestsun
老师您好,startCollectors 函数对子协程中的返回的错误判断不到。 if len(errs.CollectorErrors) == 0 { return nil }

作者回复: 很好的发现。这个是因为Agent.Start()返回时,没有等待Collector的start过程结束。所以,要修正这个问题,只要同步一下就可以。 func (agt *Agent) startCollectors() error { var err error var errs CollectorsError var mutex sync.Mutex var wg sync.WaitGroup for name, collector := range agt.collectors { wg.Add(1) go func(name string, collector Collector, ctx context.Context) { defer func() { mutex.Unlock() }() err = collector.Start(ctx) mutex.Lock() if err != nil { errs.CollectorErrors = append(errs.CollectorErrors, errors.New(name+":"+err.Error())) } wg.Done() }(name, collector, agt.ctx) } wg.Wait() return errs }

2020-03-10
4
Geek_tgq
老师,您好,这课中有一个地方不是很理解。 startCollectors函数中mutex是要对errs.CollectorErrors这个slice进行加锁吗?感觉这里可以不加锁,加锁是为了什么?另外外层函数对子协程中的返回的错误判断不到。 if len(errs.CollectorErrors) == 0 { return nil }

作者回复: 因为Collector工作在不同的协程中,所以访问CollectorErrors([] error)添加错误时,需要通过同步量(mutex)来实现线程安全。

2020-02-23
Geek_007
老师 。 if err = agt.Start();err != nil { goto ERR } 这样写会出错,因为err 就是 != nil 了。我试了好多次,都无法对start的返回值进行错误判断, 似乎因为 Start() 的error 被CollectorsError 封装了一层的缘故,老师能给下 Start() 如何进行错误判断的方式吗?

作者回复: func (agt *Agent) startCollectors() error { var err error var errs CollectorsError var mutex sync.Mutex for name, collector := range agt.collectors { go func(name string, collector Collector, ctx context.Context) { defer func() { mutex.Unlock() }() err = collector.Start(ctx) mutex.Lock() if err != nil { errs.CollectorErrors = append(errs.CollectorErrors, errors.New(name+":"+err.Error())) } }(name, collector, agt.ctx) } if len(errs.CollectorErrors) == 0 { return nil } return errs } 在相关代码中添加: if len(errs.CollectorErrors) == 0 { return nil }

2019-08-13
2
收起评论