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
收藏
沉浸
阅读
分享
手机端
回顶部
当前播放: 30 | 只运行一次
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)

  • 最新
  • 精选
我还是不懂
为什么不能这样写不是取地址么,地址还不同 func TestSingle(t *testing.T) { var wg sync.WaitGroup for i := 0; i < 10; i++ { wg.Add(1) go func() { obj := GetSingleObj() //fmt.Printf("%x\n", unsafe.Pointer(obj)) fmt.Println(&obj) wg.Done() }() } wg.Wait() } === RUN TestSingle create obj 0xc0000b2000 0xc000006040 0xc000006048 0xc000006050 0xc000006058 0xc000006060 0xc000006068 0xc000006080 0xc000006070 0xc000006078 --- PASS: TestSingle (0.00s) PASS

作者回复: 其实obj已经是一个指针变量了,你可以看看GetSingleObj的返回值定义,所以&obj就不对了,变成了指向指针的指针。

2019-07-26
6
真名不叫黄金
感谢老师,讲得很好~ 有一个小问题想请教: 这个单例的例子,应该是存在return的obj为未初始化的情况对吗?因为once.Do中如果执行耗时操作,那么在这个function被第二次调用时,可能初始化还未完成,但是并不会运行第二次Once中的代码,那么返回的就是未初始化的object。因此实际生产中应该不能够这样使用是吗

作者回复: 不会的。 第二次的调用会被阻塞,直到初始化过程完成。

2020-04-12
1
小寞子。(≥3≤)
我把singleton 传值给另一个 func, 然后里面修改singleton 但是在外面却并没体现出新值。 而且地址也变了。

作者回复: 粘贴一下你的代码看看。

2021-01-06
张sir
您好,我想问下,sync.once都用在哪些场景下,能举个例子吗

作者回复: 可以用在类似于单例模式的场景。避免资源的反复初始化等

2020-03-15
manatee
麻烦老师把20课后的代码上传一下github,另外想请问下视频中fmt.Printf("%x\n", unsafe.Pointer(obj))unsafe.Pointer的用法是怎么样的呢

作者回复: 前期代码的章节划分和视频有所不一致。你要以代码章节里的子目录的名称来找一下。代码会尽快联系平台上传

2019-04-02
2
Vincent
就Griffin和PlaN{Zn}的留言,做了下实验,结果是这样: 如果type Singleton struct {} 定义的是空结构体,那么无论用不用once.Do(),最后得到的obj地址都是一样的。当然不用once.Do()时,除了输出10个相同的地址,还会输出10次“Create obj“。 将Singleton结构体里添加内容后,比如type Singleton struct {a bool},再做实验,每次运行就会得到不同的地址了。
2019-04-02
6
12
强哥
这个视频里,例子中的java单例不是线程安全的,缺少volatile修饰共享变量的。需要禁止重排序。
2019-04-07
5
11
虢國技醬
fmt.Printf("%p\n", obj) 也可以输出地址
2019-08-15
9
Griffin
感觉取地址有点问题,多次运行得到的地址每次都一样。
2019-03-26
6
PlaN{Zn}
把once.do注释掉之后,“Create obj”是输出了多次,但是singleInstance的地址依然都是一样的
2019-03-27
3
2
收起评论