V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
mmnnyycc
V2EX  ›  程序员

go 关键字之后,怎么不输出了?

  •  
  •   mmnnyycc · 2018-02-05 15:18:23 +08:00 · 3003 次点击
    这是一个创建于 2485 天前的主题,其中的信息可能已经有所发展或是发生改变。

    想请求一批接口,假如有 50 个,互不依赖,结果综合一下输出,每个耗时 0.5 秒,加起来时间就很多了。想使用关键字 go 测试一下。

    package main
    
    import (
    	"time"
    	"log"
    )
    
    func test(t int) {
    	time.Sleep(2 * time.Second)
    	log.Println("func test------>", t)
    }
    func main() {
    	for a := 0; a < 5; a++ {
    		go test(a)
    	}
    }
    
    

    在循环里,直接调用的话,控制台没 2 秒输出一次,使用 go 关键字,一个都没输出,也没报错?求问?

    12 条回复    2018-02-06 10:15:38 +08:00
    ki5
        1
    ki5  
       2018-02-05 15:19:35 +08:00
    你的程序直接退出了,输出个鬼啊
    mmnnyycc
        2
    mmnnyycc  
    OP
       2018-02-05 15:23:47 +08:00
    @ki5 我调用了 5 次 test 函数,函数里面有输出啊
    faceair
        3
    faceair  
       2018-02-05 15:25:17 +08:00
    虽然 goroutine 没退,但你 main 函数执行完整个进程就退出了 你可以在 main 结尾加个 select {} 阻塞一下
    mmnnyycc
        4
    mmnnyycc  
    OP
       2018-02-05 15:26:26 +08:00
    @faceair 感谢
    Yoock
        5
    Yoock  
       2018-02-05 15:41:02 +08:00 via iPhone
    或者用 waitgroup
    mmnnyycc
        6
    mmnnyycc  
    OP
       2018-02-05 15:44:13 +08:00
    @faceair
    ```
    func SubTest(t int) {
    time.Sleep(2 * time.Second)
    fmt.Println("subtest=====>", t)
    }

    func Test() {
    //time.Sleep(2 * time.Second)
    for ; ; {
    time.Sleep(5 * time.Second)
    for a := 0; a < 5; a++ {
    go SubTest(a)
    }
    fmt.Println("func test------>", time.Now())
    }
    }
    func main() {
    go Test()
    select {}
    }
    ```
    试了一下果然可以
    TanLian
        7
    TanLian  
       2018-02-05 17:43:51 +08:00
    用 channel 吧
    xuyl
        8
    xuyl  
       2018-02-05 17:56:30 +08:00
    哈哈,一看就是新手。别问我怎么知道的,我也刚看到 gorutines
    mmnnyycc
        9
    mmnnyycc  
    OP
       2018-02-05 18:56:21 +08:00
    @TanLian 没用过
    itfanr
        10
    itfanr  
       2018-02-05 22:27:45 +08:00 via Android
    主先退出了 可以 sleep 一下 再退出主
    q397064399
        11
    q397064399  
       2018-02-06 10:05:47 +08:00
    @mmnnyycc #9 其实你把 groutine 当做线程就好了,, 主线程中的逻辑走完了,自然就退出了, 其它子线程还没来得及输出呢,,你可以在 main 函数中 使用 sleep 函数 停留几十秒,,这个算是多线程 协程编程的常识吧, 即使 fork()调用 ,如果父进程 退出了,子进程也是不会输出任何东西的。
    q397064399
        12
    q397064399  
       2018-02-06 10:15:38 +08:00
    @mmnnyycc #6 收回最后一句 ,父进程退出了,子进程还是会输出东西的
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   5936 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 01:48 · PVG 09:48 · LAX 17:48 · JFK 20:48
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.