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

2018 年 2 月 5 日
 mmnnyycc

想请求一批接口,假如有 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 关键字,一个都没输出,也没报错?求问?

3539 次点击
所在节点    程序员
12 条回复
ki5
2018 年 2 月 5 日
你的程序直接退出了,输出个鬼啊
mmnnyycc
2018 年 2 月 5 日
@ki5 我调用了 5 次 test 函数,函数里面有输出啊
faceair
2018 年 2 月 5 日
虽然 goroutine 没退,但你 main 函数执行完整个进程就退出了 你可以在 main 结尾加个 select {} 阻塞一下
mmnnyycc
2018 年 2 月 5 日
@faceair 感谢
Yoock
2018 年 2 月 5 日
或者用 waitgroup
mmnnyycc
2018 年 2 月 5 日
@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
2018 年 2 月 5 日
用 channel 吧
xuyl
2018 年 2 月 5 日
哈哈,一看就是新手。别问我怎么知道的,我也刚看到 gorutines
mmnnyycc
2018 年 2 月 5 日
@TanLian 没用过
itfanr
2018 年 2 月 5 日
主先退出了 可以 sleep 一下 再退出主
q397064399
2018 年 2 月 6 日
@mmnnyycc #9 其实你把 groutine 当做线程就好了,, 主线程中的逻辑走完了,自然就退出了, 其它子线程还没来得及输出呢,,你可以在 main 函数中 使用 sleep 函数 停留几十秒,,这个算是多线程 协程编程的常识吧, 即使 fork()调用 ,如果父进程 退出了,子进程也是不会输出任何东西的。
q397064399
2018 年 2 月 6 日
@mmnnyycc #6 收回最后一句 ,父进程退出了,子进程还是会输出东西的

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://study.congcong.us/t/428595

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX