gpt4 book ai didi

Golang 例程提前终止

转载 作者:数据小太阳 更新时间:2023-10-29 03:37:28 24 4
gpt4 key购买 nike

我刚开始使用 go 并编写了我的第一个程序,但输出结果不如预期。我写了一个异步例程 addUrl,它将 url 添加到 channel 5000 次,然后 consumeUrl 从 channel 中删除并打印它。该例程仅运行 9 次。为什么?下面是代码和输出

package main

import "fmt"
import "time"

var urlCount = 0

func main(){

urlHolder := make(chan string,5000)

fmt.Printf("Starting program")

go addUrls(urlHolder)

time.Sleep(time.Millisecond * 100)
go consumeUrls(urlHolder)

fmt.Printf("Done")

}

func addUrls(urlHolder chan string){
var myurl string = "https://example.com/"

for i:=0; i<5000 ; i++ {
urlHolder<-myurl
fmt.Printf(" %d url added \n",i)
time.Sleep(time.Millisecond * 10)
}

}

func consumeUrls(urlHolder chan string) {
urlCount++
urlsConsumed := <- urlHolder
fmt.Printf("Pulled url %d",urlCount," ",urlsConsumed,"\n")
time.Sleep(time.Millisecond * 20)
}

输出是

Starting program
0 url added
1 url added
2 url added
3 url added
4 url added
5 url added
6 url added
7 url added
8 url added
Done

为什么当循环为 5000 时它会在 8 点终止?

最佳答案

您正在使用 time.Sleep 等待 main 完成,但您确实应该使用 WaitGroups。

这样您就不必尝试任意选择一些时间并希望它足以让您的程序完成,或者担心设置太多时间而您的程序无所事事。

我已将 WaitGroups 的实现添加到您的代码中:

https://play.golang.org/p/1zn2JYefaA

此外,您的 consumeUrls 函数的编写方式没有正确循环,您无法打印 channel 中的所有内容。但由于这不是您的具体问题,我不会在这里解决。

关于Golang 例程提前终止,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40315686/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com