jjzjj

goroutine

全部标签

Goroutines 和 mutex

关闭。这个问题需要detailsorclarity.它目前不接受答案。想改进这个问题吗?通过editingthispost添加细节并澄清问题.关闭4年前。Improvethisquestionfunc(s*Server)start(){s.Lock()defers.Unlock()if!s.isClosed{gos.processing()}gos.start()}func(s*Server)processing(){s.Lock()//dostuffs.Unlock()}我有一个工作的Golang项目,其中有一段代码遵循上面显示的逻辑。我不明白为什么这个逻辑像我预料的那样会出现死锁。

go - append() 在原子/线程中是安全的吗?

阅读几个列表后,我想将每个列表中的所有行添加到一个大数组中。我在它自己的goroutine中运行每个列表阅读器。我可以在阅读后立即追加一行吗?这个线程是保存还是可以在我手中爆炸?typelistHolder{entries[]entry}func(h*listHolder)readAllLists(s[]list){c:=make(chanlist)varwgsync.WaitGroupfor_,l:=ranges{wg.Add(1)goh.readSomeList(&wg,l)}c.close()wg.Wait()}func(h*listHolder)readSomeList(wg*

go - 所有goroutine都处于 sleep 状态-死锁(无限循环+选择)

我有一个应用程序,每隔几秒钟就创建一个从api获取当前价格的例程。然后它将响应发送到监视例程以进行分析。如果监视器发现价格有明显变化,它会发送一个通知。如果每次执行程序之间的延迟较大,则可以正常工作。如果它很小,它不会:“致命错误:所有goroutine都处于休眠-死锁状态!”被触发,程序崩溃。我猜(?)死锁是由以下原因造成的:(1)监视器充斥着新的价格信息(并且未能及时分析这些信息);或(2)主功能被监视器的消息所淹没。在主函数将新价格附加到一个切片上的同时,监视器正在遍历它,这一事实可能也有一些缺点。如何解决这个问题?在阅读其他文章时,我认为“select”语句是一种神奇的治疗方法

go - 为什么 Goroutines 的执行时间相差很大?

我只是在测量一组goroutine的执行时间。这意味着:我开始测量,然后启动20个goroutine并在它们完成后立即停止测量。我重复该过程大约4次,然后比较4次执行时间。有时,这些执行时间会有很大差异:20个goroutine的第一次运行:1.2毫秒20个协程的第2次运行:1.9毫秒20个协程的第3次运行:1.4毫秒20个goroutine的第4次运行:17.0毫秒!为什么有时差异如此之大?有什么办法可以避免吗? 最佳答案 Whydoesitsometimesdiffersosignificantly?执行时间在某些时候总是不可预

go - 如何从 channel 接收直到它在 GO 中具有值

一个函数有一个循环,它在其中调用一个go例程,并将一个channel传递给它。在此之后,我尝试从channel接收直到它有值。go函数在每次调用时在channel中传递值。我的channel无限运行。func(m*StreamsDAO)FindOutput(输入模型.输入)([]模型.输出,错误){//SOMECODEvarchanNumberint=(input.EndTime-input.StartTime)/60outputChan:=make(chanmodel.Output,chanNumber)fori:=input.StartTime;ifuncForEachSlide(

go - 从另一个 goroutine 启动一个 goroutine 是什么意思?

来自thisfile,我不明白为什么函数startWorker会这样写:func(p*WorkerPool)dispatch(){fori:=0;ifuncstartWorker(taskChanchanfunc()){gofunc(){vartaskfunc()varokboolfor{task,ok=如果我是开发者,我会这样写这个函数:funcstartWorker(taskChanchanfunc()){vartaskfunc()varokboolfor{task,ok= 最佳答案 根据GoBestPracticesFranc

go - 避免在带有接口(interface)的范围内的 goroutine 中进行数据竞争

我有以下for...rangeblock,它使用goroutine调用url。funccallUrls(urls[]string,reqBodyinterface{})[]*Response{ch:=make(chan*Response,len(urls))for_,url:=rangeurls{somePostData:=reqBody//thisjustseemstocopyreference,notadeepcopygofunc(urlstring,somePostDatainterface{}){//serviceMutex.Lock()//deferserviceMutex.

go - 一个 goroutine 从结构中读取而另一个 goroutine 正在修改它是否安全?

更具体地说,在我的例子中,我有一个网络服务器和一个全局可访问的结构,网络服务器使用它来生成页面。我有另一个Goroutine,它总是定期用新值更新该结构。这会引起问题吗?我是否需要实现一种机制来确保它在更新时不被读取? 最佳答案 不,这正是不安全的定义,会被racedetector捕获如果你测试过它。您绝对需要同步访问,例如使用sync.Mutexorsync.RWMutex.如果始终拥有最新值并不重要,您还可以允许每个goroutine缓存结构的副本,然后每隔一段时间定期从“主”副本更新它们的副本经常。如果经常访问该结构,这有助于

go - 我想在 goroutines 之间通信并无限期地阻塞主线程

我如何阻止mainfunc并允许goroutines通过channel进行通信以下代码示例会抛出错误0fatalerror:所有goroutines都睡着了-死锁!packagemainimport("fmt""time")funcmain(){ch:=make(chanint)gofunc(){value:= 最佳答案 我想你想打印所有值[0:99]。然后你需要在第一个goroutine中循环。另外,你需要传递信号来打破循环funcmain(){ch:=make(chanint)stopProgram:=make(chanbool

go - panic : runtime error: invalid memory address or nil pointer dereference [signal 0xc0000005 code=0x0 addr=0x8 pc=0x48be5c] goroutine 1 [running]:

我正在尝试使用链表实现多项式的加法。该程序成功地添加了幂0系数,但在第一次遍历后它出现了困惑。这是我到目前为止编写的代码。在初始化temp1!=nil之后,循环遍历else但当权力不同时不进入if循环并进入panic状态packagemainimport("fmt")typeNodestruct{coefficientintpowerintnext*Node}typeliststruct{head*Nodecountint}funcmain(){list1:=&list{}list1.addVariable(5,2)list1.addVariable(4,1)list1.addVari