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

全部留言(10)

  • 最新
  • 精选
Coder4
老师,有关于加厚模式的书推荐么? 或者介绍各种架构模式的资料。

作者回复: 可以看看“面向模式的软件架构”

2019-04-10
2
包子
怎么让这个程序中的filter多线程执行

作者回复: 那这个采用多线程需要考虑 1. 线程安全,可以考虑使用csp/channel 2. fliter分别获去数据,如pipe实现为channel,则filter接收channel中的数据

2020-07-30
1
yan
我使用go test -v,依旧显示./split_filter_test.go:9:8: undefined: NewSplitFilter,这是什么原因啊

作者回复: 这是由于被依赖的go文件没有被加入编译,可以采用 go test -v ./*

2021-08-09
yan
老师,我想问一下split_filter.go 和 split_filter_test.go 再同一个package下,为什么split_filter_test.go无法引入NewSplitFilter啊?搞了好久没搞明白,代码无法运行。

作者回复: 用以下命令行 运行 go test -v ./*

2021-08-09
NEVER SETTLE
func TestWrongInput(t *testing.T) { sf := NewSplitFilter(",") _, err := sf.Process(123) if err == nil { t.Fatal("An error is expected.") } } 是不是 if err != nil { t.Fatal("An error is expected.") }

作者回复: 不是,这里我期望返回错误,所以如果err为空就不符合预期了

2019-04-14
松小鼠
这就是责任链+装饰器模式啊
2020-07-29
5
www
例子代码写得真好,细节中看到很多差距,学习了
2020-06-22
3
escray
Filter 封装了数据处理功能,包括处理参数、填充、根据 Filter 内容召回广告或者排序 Filter 就是给它数据,然后等待数据处理的结果,只和数据格式或者数据类型耦合,只要传递给他的数据格式或者类型可以处理 在处理过程中可以加入新的 Filter 进行扩展 分布式系统中的 Pipe 可能需要一个网络连接或者在异步环境中的 buffer,在进程内部,就是方法调用 pipe-filter framework 类似于 Unix 或者 Linux 的管道指令 课程里面说可以形成组合模式,留言里面也有同学说类似于 责任链+装饰器模式
2021-04-11
2
o9
大佬好,不太理解 StraightPipeline 中的 `Filters *[]Filter` 为什么要声明成 切片指针类型呢
2021-09-10
Alvin-L
责任链模式。如果配合JAVA来对比说明可能效果会好一些。
2020-04-19
收起评论