草庐IT

例程分享

全部标签

go - 为什么 GO 例程不启动?

我写了一个简单的GO程序,应该启动3个GO例程。但是,GO例程不会启动。请注意,情况与这篇文章中的描述者不同:Whyismygoroutinenotexecuted?程序应该等待GO例程结束它们的执行...因此,程序应该永远等待(因为例程永远不会停止)。packagemainimport("fmt""net""os""time""sync")funcmain(){wg:=sync.WaitGroup{}fmt.Print("Starting3clients\n")fori:=0;istarted\n",inName)wg.Add(1)conn,err:=net.Dial("tcp","

go - 从不同的 go 例程将数据写入同一 channel ,无需 WaitGroup 即可正常工作

在等待wg.Wait()后,当使用多个带WaitGroup的go例程将数据写入同一channel时,出现异常,表示所有go例程都处于休眠状态或锁死状态。packagemainimport("fmt""runtime""sync")varwgsync.WaitGroupfuncCreateMultipleRoutines(){ch:=make(chanint)fori:=0;i当尝试在没有WaitGroup的情况下实现这一点时,我能够通过循环将数据推送到channel的确切次数从channel读取数据,但我无法调整范围,因为当我们关闭channel时会出现panic。这是示例代码pack

go - 匿名函数似乎没有在 Go 例程中执行

我有以下代码。特别注意匿名函数:funcsaveMatterNodes(matterIdint,nodes[]doculaw.LitigationNode)(bool,error){var(errerrorresp*http.Response)//Dothisinmultiplethreadsfor_,node:=rangenodes{fmt.Println("inloops")gofunc(){postValues:=doculaw.LitigationNode{Name:node.Name,Description:node.Description,Days:node.Days,Da

go - 检测 Go 例程中断

有没有办法检测go例程在执行时是否被中断?我想要类似于Java中的InterruptedException的东西:https://docs.oracle.com/javase/8/docs/api/java/lang/InterruptedException.html 最佳答案 InterruptedException如果线程被中断,则抛出Java中的异常,例如与Thread.interrupt()方法(当它正在等待、sleep或以其他方式占用时)。在Go中,您不能从外部中断goroutine(参见cancelablockingop

Golang 例程提前终止

我刚开始使用go并编写了我的第一个程序,但输出结果不如预期。我写了一个异步例程addUrl,它将url添加到channel5000次,然后consumeUrl从channel中删除并打印它。该例程仅运行9次。为什么?下面是代码和输出packagemainimport"fmt"import"time"varurlCount=0funcmain(){urlHolder:=make(chanstring,5000)fmt.Printf("Startingprogram")goaddUrls(urlHolder)time.Sleep(time.Millisecond*100)goconsume

go - 在带有闭包的循环中生成 go 例程

我有一个字符串列表,其中可以包含1到100,000之间的元素数。我想验证每个字符串,看看它们是否存储在数据库中,这需要调用网络。为了最大限度地提高效率,我想为每个元素生成一个goroutine。目标是如果go例程函数内部的验证之一返回err,则返回false,如果没有err,则返回true。因此,如果我们发现至少一个err,我们就可以停止,因为我们已经知道它将返回false。这是基本思路,下面的函数是我目前一直在考虑使用的结构。我想知道是否有更好的方法(也许使用channel?)。for_,id:=rangeuserIdList{gofunc(idstring){user,err:=v

google-app-engine - Go例程泄漏在哪里?

我正在尝试并发运行多个任务,如果有任何错误则立即返回,而无需等待所有例程返回。代码如下所示。我已经去除了噪音以使其更容易消化,但如果泄漏不明显,我可以发布完整的代码。值得注意的是,我正在将其部署在googleappengine上。我无法在我的机器上重现泄漏,但是当我在//Consumetheresults评论之后替换并发时,应用程序工作正常,但我不明白为什么因为代码对我来说看起来是正确的.packagemainimport"fmt"import"sync"import"errors"funcmain(){indexes:=[]int{1,2,3,4,5,6,7}devCh:=make(

go - 在 golang 中,我的 go 例程使用了所有内核,但每个内核只使用了 50% 到 75%

我使用的是go语言的go1.5.3linux/amd64版本。我有一个执行需要一些时间的数学运算的例程。每个goroutine独立行动,不必阻塞。我的系统有12个核心。如果我生成12个go例程,它只需要所有内核的平均使用率高达31%。如果我使用24个go例程,它会使所有内核的平均使用率达到49%。如果我使用240,我得到77%。2400给了我76%。显然,rand.Intn(j)操作正在减慢它的速度。没有它,内核将以100%的速度运行。funcDoSomeMath()int{k:=0fori:=0;i如何让程序在使用RNG时100%使用所有内核? 最佳答案

go - conn.Read 在通过其他 go 例程关闭 conn 时进入无限循环

我的代码有点复杂,但简单来说,它有多个go例程,所有都调用不同的TCP服务器,并在流中出现可读消息时在for循环中读取输入。到目前为止,一切都很好。现在有另一个go例程来管理之前的一堆“客户端”并在用户需要时关闭它们。为此,我将每个“conn”与适当的goroutine客户端相关联并关闭它。我面临的问题是,只要我调用任何conn对象的close函数,其对应的Read函数就会进入无限循环,不断读取空字符串。我写了一个简单的代码,类似于我在多个go例程中处理连接的方式-https://play.golang.org/p/wq7zt9Kqz7长话短说简而言之,我有一个“类”,它代表一个远程服

go - 如果我们无法从传递给该例程的 channel 收听,如何停止 goroutine

我遇到了一个关于goroutines的问题。假设有一个channel,我们通过来自main的goroutine传递这个channel。现在,如果我们无法从main收听此channel(以防在收听之前发生返回/panic)。goroutine不会停止。如何在出错时停止这个goroutine?在多次调用goroutine中的函数的情况下,routine的数量不断增加。packagemainimport("fmt""runtime")functest(achanstring){deferfunc(){close(a)fmt.Println("channelclose")}()fmt.Prin