time.Sleep引发goroutine调度问题

abing10631 · 2017-04-06 02:14:03 · 2603 次点击 · 大约8小时之前 开始浏览    置顶
这是一个创建于 2017-04-06 02:14:03 的主题,其中的信息可能已经有所发展或是发生改变。

运行环境:mac go的版本是1.5 协程中使用time.Sleep的时候造成死锁,麻烦哪位大神给解答下。

代码1: 运行正常

func test_sleep(index int){
    for i:=0;i<100;i++{
        fmt.Println("index:", index, " i:",i)
    }
    wg.Done()
}

var wg sync.WaitGroup

func main(){
    runtime.GOMAXPROCS(8)

    for i:=1;i<11;i++{
        wg.Add(1)
        go test_sleep(i)
    }
    wg.Wait()
}

代码2: 执行一段时间,就像死锁一样

func test_sleep(index int){
    for i:=0;i<100;i++{
        fmt.Println("index:", index, " i:",i)
                //添加time.Sleep就出现问题
        time.Sleep(5*time.Millisecond)
    }
    wg.Done()
}

var wg sync.WaitGroup

func main(){
    runtime.GOMAXPROCS(8)

    for i:=1;i<11;i++{
        wg.Add(1)
        go test_sleep(i)
    }
    wg.Wait()
}

有疑问加站长微信联系(非本文作者)

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

2603 次点击  
加入收藏 微博
3 回复  |  直到 2017-04-07 06:07:18
yangheng
yangheng · #1 · 8年之前

测试过了,go1.8版本没有问题

polaris
polaris · #2 · 8年之前

我试了没问题,不过版本是 1.8

abing10631
abing10631 · #3 · 8年之前
polarispolaris #2 回复

我试了没问题,不过版本是 1.8

多谢,我升级到1.8没有这个问题了,估计是1.5的bug

添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传