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

全部留言(8)

  • 最新
  • 精选
卜凌峰
package main import ( "fmt" "net/http" ) func main() { http.HandleFunc("/", func(rw http.ResponseWriter,r *http.Request) { fmt.Println("hello world") }) http.HandleFunc("/hello", func(rw http.ResponseWriter,r *http.Request) { str:="hello word" rw.Write([]byte(str)) }) http.ListenAndServe(":8080",nil) } 调用127.0.0.1:8080 会打印两次Hello world。 调用127.0.0.1:8080/hello则只会打印一次hello world。这个是什么策略呢 老师

作者回复: 应该是你浏览器的问题吧。 你采用命令行调用如下: curl 127.0.0.1:8080 curl 127.0.0.1:8080/ 结果都是一样的,只显示一次“hello world”

2020-08-12
2
春春家的雷雷
超哥,感觉这节课刚开始很紧张呢😁

作者回复: 哈哈,你的感觉没错

2019-06-16
我爱北京天安门
落后了终于追上了 可以松口气了。0分06秒老师咽口水的声音 。。。萌萌的
2019-04-12
12
芝士老爹
呃,测试的时候,注意浏览器缓存,别因为缓存影响结果。 唉,不说了,都是泪。
2019-04-16
2
确认过眼神
比如/images会匹配...images后面是不是应该有个/,对吧?
2019-10-05
1
1
escray
抄了一遍代码,比较怀念 Rails 里面相对简单的 Router 机制,不知道 Go 语言是否有类似的框架。即使没有,估计很快也会有人写出来一个的。 有一个同学提问 ``` http.HandleFunc("/", func(rw http.ResponseWriter,r *http.Request) { fmt.Println("hello world") }) ``` 为什么访问的时候会在命令控制台上打印两次?我也不是特别清楚,但应该是和浏览器的访问机制有关。 访问 127.0.0.1:8080 会打印两次; 访问其他任何有路由的地址,都会打印一次; 访问没有路由的空地址,打印一次 按照路由规则,定义了根目录的 "/" 之后,似乎是可以匹配任何路径的,在一定程度上部分解释了上面的问题,访问任何地址,都至少打印一次。 另外,浏览器会屏蔽掉一些细节,比如 404 访问,一般会以空白页展示,可以考虑采用 ``` curl -i 127.0.0:8080 ``` 来查看详细的 Response 头。
2021-04-13
escray
抄了一遍代码,比较怀念 Rails 里面相对简单的 Router 机制,不知道 Go 语言是否有类似的框架。即使没有,估计很快也会有人写出来一个的。 有一个同学提问 ``` http.HandleFunc("/", func(rw http.ResponseWriter,r *http.Request) { fmt.Println("hello world") }) ``` 为什么访问的时候会在命令控制台上打印两次?我也不是特别清楚,但应该是和浏览器的访问机制有关。 访问 127.0.0.1:8080 会打印两次; 访问其他任何有路由的地址,都会打印一次; 访问没有路由的空地址,打印一次 按照路由规则,定义了根目录的 "/" 之后,似乎是可以匹配任何路径的,在一定程度上部分解释了上面的问题,访问任何地址,都至少打印一次。 另外,浏览器会屏蔽掉一些细节,比如 404 访问,一般会以空白页展示,可以考虑采用 ``` curl -i 127.0.0:8080 ``` 来查看详细的 Response 头。
2021-04-13
1
郭星
"以/ 结尾的 URL 可以匹配它的任何⼦路径,⽐如 /images 会匹配 /images/cute-cat.jpg" 这句话我没有理解 http.HandleFunc("/sub/", func(writer http.ResponseWriter, request *http.Request) { fmt.Fprint(writer," leafTree sub") }) http.HandleFunc("/sub/node", func(writer http.ResponseWriter, request *http.Request) { fmt.Fprint(writer," leafNode sub") }) 当我访问 /sub 时实际访问到的是 /sub/,并没有访问 /sub/node
2020-07-24
收起评论