
想请求一批接口,假如有 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 关键字,一个都没输出,也没报错?求问?
1 ki5 2018-02-05 15:19:35 +08:00 你的程序直接退出了,输出个鬼啊 |
3 faceair 2018-02-05 15:25:17 +08:00 虽然 goroutine 没退,但你 main 函数执行完整个进程就退出了 你可以在 main 结尾加个 select {} 阻塞一下 |
5 Yoock 2018-02-05 15:41:02 +08:00 via iPhone 或者用 waitgroup |
6 mmnnyycc OP @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 {} } ``` 试了一下果然可以 |
7 TanLian 2018-02-05 17:43:51 +08:00 用 channel 吧 |
8 xuyl 2018-02-05 17:56:30 +08:00 哈哈,一看就是新手。别问我怎么知道的,我也刚看到 gorutines |
10 itfanr 2018-02-05 22:27:45 +08:00 via Android 主先退出了 可以 sleep 一下 再退出主 |
11 q397064399 2018-02-06 10:05:47 +08:00 @mmnnyycc #9 其实你把 groutine 当做线程就好了,, 主线程中的逻辑走完了,自然就退出了, 其它子线程还没来得及输出呢,,你可以在 main 函数中 使用 sleep 函数 停留几十秒,,这个算是多线程 协程编程的常识吧, 即使 fork()调用 ,如果父进程 退出了,子进程也是不会输出任何东西的。 |
12 q397064399 2018-02-06 10:15:38 +08:00 @mmnnyycc #6 收回最后一句 ,父进程退出了,子进程还是会输出东西的 |