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

Go语言从入门到实战

共55讲 · 55课时,约700分钟
6092
免费
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 | 结束语
本节摘要
展开

精选留言(11)

  • 2019-03-21
    老师,我的代码如下,但是每次运行结果都不准确
    var wg sync.WaitGroup
    func TestIncreaseCounter(t *testing.T){
        counter := 0
        for i:=0;i<1000 ;i++ {
            wg.Add(1)
            go func() {
                counter++
                wg.Done()
            }()
        }
        wg.Wait()
        t.Log("Counter = " + strconv.Itoa(counter))
    }
    找了半天错误,我还是找不到为什么错误,请老师指导
    展开

    作者回复: 这个是因为counter不是线程安全的,要用sync.Mutex的lock来同步,参考视频

    3
  • 2019-06-05
    初学语言,使用中文解释,方便理解
    ```
    // M -- System Thread 「系统线程」
    // P -- Processor 「Go 语言的协程处理器」
    // G -- Goroutine 「协程」
    func TestGroutine(t *testing.T) {
        for i := 0; i < 10; i++ {
            // fmt.Println(i)
            go func(par int) { // 使用go创建协程,但是需要注意的是:协程函数的par作为参数是外部i的数据拷贝
                fmt.Println(par)
            }(i)
        }
        time.Sleep(time.Millisecond * 50)
    }
    ```
    展开

    作者回复: 非常感谢!

    1
    1
  • 2019-03-20
    怎么使用go实现高并发web系统
    1
  • 2019-08-02
    老师好,我在做测试的时候 报错 panic: inconsistent poll.fdMutex
    代码:
    package groutine_my_test

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

    func TestGo(t *testing.T) {
        //var wt sync.WaitGroup
        for i := 0; i<=5000001; i++ {
            //wt.Add(1)
            go func (i int) {
                fmt.Println(i)
                //wt.Done()
            }(i)
        }
        //wt.Wait()
        t.Log("end");
    }
    网上查找 说golang 起超过100W的goroutine就会crash 是这个原因。我也没太理解,能帮忙解答一下么?
    展开
  • 2019-06-14
    老师,您好,go func(par int) {
                fmt.Println(par)
            }(i)
    这最后的括号里面传参是干什么的

    作者回复: 是那个par的值,作为参数传人

    1
  • 2019-06-09
    你好,检查g的数量一只保持不变,然后在g的栈里打一个标记,然后。。。这里描述不清楚,请耐心讲解下,谢谢!
  • 2019-05-23
    老师你好,我想问下go的协程跟python的协程一样吗,不一样的话哪里不一样?

    作者回复: go的协程本质是系统的线程调用,而Python中的协程是eventloop模型实现,所以虽然都叫协程,但并不是一个东西

    1
  • 2019-05-13
    老师!请教问题:我一直以为go调度不会中断持续运行中的gorouting,可下面两个例子的结果让我凌乱了

    package main

    import (
        "log"
        "runtime"
    )

    func main(){
        runtime.GOMAXPROCS(1)
        
        for{
            go func() {
                log.Println("0")
            }()
            log.Println("1")
        }
    }
    这样会0,1交替输出,而

    package main

    import (
        "log"
        "runtime"
    )

    func main(){
        runtime.GOMAXPROCS(1)
        go func() {
            log.Println("0")
        }()
        for{

            log.Println("1")
        }
    }
    只会输出1,请问gorouting 是怎样调度的?
    展开

    作者回复: Goroutine的调度是这样的
    启动的时候,会专门创建一个线程sysmon,用来监控和管理,在内部是一个循环:

    1.     记录所有P的G任务计数schedtick,(schedtick会在每执行一个G任务后递增)

    2.     如果检查到 schedtick一直没有递增,说明这个P一直在执行同一个G任务,如果超过一定的时间,就在这个G任务的栈信息里面加一个标记

    3.     然后这个G任务在执行的时候,如果遇到非内联函数调用,就会检查一次这个标记,然后中断自己,把自己加到队列末尾,执行下一个G



    你可以试试下面这个程序,多运行一会,你就会看到切换

    func doSomething(i int) {
        fmt.Print(i)
    }

    func main() {
        runtime.GOMAXPROCS(1)
        go func() {
            for {
                doSomething(0)

            }
        }()
        for {
            doSomething(1)

        }

    }

    1
  • 2019-05-03
    @walf 更多细节你可以看两本书《GO语言学习笔记》《GO并发编程实战》
  • 2019-04-19
    老师,我有个疑问,既然协程的执行器会去切出阻塞的协程,为什么还需要调度器去把阻塞执行器中的任务均衡到空闲的执行器上呢?

    作者回复: 这里不是很方便输入很多文字。推荐可以看看这两篇

    https://m.imooc.com/mip/article/42071
    https://studygolang.com/articles/11862?open_source=weibo_search

  • 2019-04-08
    对于图例的协程机制,并不是很清晰运行的机制,能否在讲解的时候加入一些动态图示的部分。