下载APP
登录
关闭
讲堂
算法训练营
Python 进阶训练营
企业服务
极客商城
客户端下载
兑换中心
渠道合作
推荐作者
当前播放: 31 | 仅需任意任务完成
00:00 / 00:00
标清
  • 标清
1.0x
  • 2.0x
  • 1.5x
  • 1.25x
  • 1.0x
  • 0.5x
网页全屏
全屏
00:00
付费课程,可试看

Go语言从入门到实战

共55讲 · 55课时,约700分钟
6133
免费
01 | Go语言课程介绍
免费
02 | 内容综述
免费
03 | Go语言简介:历史背景、发...
免费
04 | 编写第一个Go程序
免费
05 | 变量、常量以及与其他语言...
06 | 数据类型
07 | 运算符
08 | 条件和循环
09 | 数组和切片
10 | Map声明、元素访问及遍历
11 | Map与工厂模式,在Go语言...
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 framew...
42 | 实现micro-kernel frame...
43 | 内置JSON解析
44 | easyjson
45 | HTTP服务
46 | 构建RESTful服务
47 | 性能分析工具
48 | 性能调优示例
49 | 别让性能被锁住
50 | GC友好的代码
51 | 高效字符串连接
52 | 面向错误的设计
53 | 面向恢复的设计
54 | Chaos Engineering
55 | 结束语
本节摘要
展开

精选留言(5)

  • 2019-03-26
    我比较喜欢老师一边敲代码,一边讲。这样我可以完全跟着思路走,一边就能懂。但是老师提前写好代码,上来直接讲,我有点懵,我每次得暂停把代码看明白了,再继续往下走,有时候再播放第二遍。

    作者回复: 我也希望尽量这样。主要是后面的课程内容相对前面的每一课都多不少,为满足平台对时长的限制,只能将一些代码事先准备好。也建议可以下载我们github上的代码在机器上运行和调试。谢谢

    2
  • 2019-10-28
    这么操作的话,还是有资源浪费的隐患,10个协程实际都完成了处理,应该是取回一个结果后,其他协程取消之后的处理才好。
    1
  • 2019-04-02
    老师, 如果使用sync.WaitGroup的话, 发现每次输出的, After的gorountine的数量都是不同的, 这个应该怎么理解呢?

    package ch22

    import (
        "fmt"
        "runtime"
        "sync"
        "testing"
        "time"
    )

    var wg sync.WaitGroup

    func runTask(id int) string {
        time.Sleep(time.Millisecond * 10)
        return fmt.Sprintf("The result is from %d", id)
    }

    func FirstResponse() string {
        numOfRunner := 10
        ch := make(chan string, numOfRunner)
        for i := 0; i < numOfRunner; i++ {
            go func(i int) {
                ch <- runTask(i)
            }(i)
        }
        abc := <-ch
        wg.Done()
        return abc
    }

    func TestFirstResponse(t *testing.T) {
        t.Log("Before:", runtime.NumGoroutine())
        wg.Add(1)
        t.Log(FirstResponse())
        wg.Wait()
        // time.Sleep(time.Second)
        t.Log("After:", runtime.NumGoroutine())
    }
    展开

    作者回复: 在检查协程数之前sleep一秒试试,让协程有时间完成和释放

  • 2019-03-29
    因为struct是空的, 你往里边随便丢一个成员,不加once输出的地址就不一样了
  • 2019-03-26
    这个虽然只使用了一个结果,但实际上后端也是返回了多个结果的吧?

    作者回复: 是的。只是第一个结果回来就返回接在做下面的事了