go routine打印问题

howtogo · 2018-05-21 11:42:31 · 1272 次点击 · 大约8小时之前 开始浏览    置顶
这是一个创建于 2018-05-21 11:42:31 的主题,其中的信息可能已经有所发展或是发生改变。

for 循环中使用go routine,不能打印日志,是什么情况?

package main

import (
    "fmt"
)

func task(i int) {
    fmt.Println(i)
}
func main() {
    for i := 0; i < 5; i++ {
        go task(i)
    }
}

image.png


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

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

1272 次点击  
加入收藏 微博
4 回复  |  直到 2018-05-21 17:57:40
hujian722
hujian722 · #1 · 7年之前

你time.Sleep 1秒就有了

howtogo
howtogo · #2 · 7年之前
hujian722hujian722 #1 回复

你time.Sleep 1秒就有了

那就没有意义了。

birdkiller
birdkiller · #3 · 7年之前

因为你的goroutine还没打印出来,主进程就退出了,然后就88了,你可以在主进程里等待goroutine执行完了再退出,用chan就可以实现。

howtogo
howtogo · #4 · 7年之前

@birdkiller 谢谢

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