jjzjj

goroutine

全部标签

go - go 例程 channel 中的同步问题

我正在尝试编写一个代理服务器,用于将视频文件转换为实时流。一个vod文件由多个不同比特率的子list文件组成。每个子list由多个ts段组成,每个4秒。为简单起见,我创建了一个包含2个子list的虚拟映射,每个子list包含4个ts段。我的任务是在for循环中无限地创建一个实时流。所以我在go例程4秒后发送每个ts段并写入channel,我还有一个go例程,我从这个go例程中读取并写入输出字符串。一旦所有片段结束,我将更新到loopEndchannel并重新开始。有2个不同比特率的API,每4秒后给我一个新的ts。packagemainimport("fmt""github.com/g

go - 一个go中出错关闭多个goroutine

考虑这个函数:funcdoAllWork()error{varwgsync.WaitGroupfori:=0;i在每个goroutine中,函数work()被调用了10次。如果对work()的调用在任何正在运行的goroutine中返回错误,我希望所有goroutine立即停止,并退出程序。可以在这里使用os.Exit()吗?我该如何处理?编辑:这个问题不同于howtostopagoroutine在这里,如果一个goroutine发生错误,我需要关闭所有goroutine 最佳答案 您可以使用context为这样的事情创建的包(“带

go - 如何从按特定顺序执行的 N 个 goroutine 中收集值?

下面是一个Stuff类型的结构。它有三个整数。Number,它的Double及其Power.让我们假设计算给定整数列表的double和幂是一项昂贵的计算。typeStuffstruct{NumberintDoubleintPowerint}funcmain(){nums:=[]int{2,3,4}//givennumbersstuff:=[]Stuff{}//structofstuffwithtransformedintsdouble:=make(chanint)power:=make(chanint)for_,i:=rangenums{godoubleNumber(i,double)

Goroutines 通信槽 channel 只工作一次

我第一次尝试使用go-routine和channel通信在Golang(1.12)中编写代码。我有Telegram机器人和一段代码,可以在发生某些更新和需要回答时与机器人通信。同时,我尝试放置一些Web服务,该服务将通过httpGET获取消息并将其发送给Bot。事实上它有效,但只有一次。之后Bot部分还在工作,但是httpGet请求无法执行,一直挂到超时。我尝试将channel与缓冲区一起使用,但在此它完全停止工作。//AppisastructurewithBotobjectstypeAppstruct{Router*mux.RouterBot}//Initializeismethod

go - 为什么在我的代码中 goroutine 似乎自动卡住循环变量

import("fmt")funcPrint(iint){fmt.Println(i)}funcPrintR(i*int){fmt.Println(*i)}funcmain(){fori:=0;i第二个、第三个例子得到了预期的输出,但我认为第一个例子的输出goPrint(i)应该与第二个相似,因为它们都没有使用新变量卡住i的当前值。造成差异的原因是什么? 最佳答案 Go按值传递参数。您的第一个示例实际上创建了一个新变量并将当前索引复制到其中,然后再启动新的goroutine,这与您的第三个示例相同。

go - Windows 上的 VIM-Go Debugger 结果为 "Goroutine not found"

我正在Windows上设置一个vim-go环境,大部分情况下都可以正常工作。我无法开始工作的一件事是调试器。我用:GoDebugStart启动它。这已经导致了很多关于debuglayer=rpc的错误。然后我在尝试创建断点时遇到更多与rpc相关的错误。最后,当开始使用:GoDebugNext进行调试时,它会提示Goroutinenotfound。有没有人有任何类似的问题或知道这可能是什么或缺少什么?谢谢!这是一些错误输出:ERR:2019-09-24T16:43:37+02:00infolayer=debuggerlaunchingprocesswithargs:[C:\Users\h

go - 相互并发的 Go 例程中的死锁错误

我有三个并发的go例程,如下所示,funcRoutine1(){mutex1.Lock()dosomethingmutex2.Lock()mutex3.Lock()sendinttoroutine2sendinttoroutine3*PrintSomething*mutex2.Unlock()mutex3.Unlock()receiveintsdosomethingmutex2.Lock()mutex3.Lock()sendinttoroutine2sendinttoroutine3PrintSomethingmutex2.Unlock()mutex3.Unlock()dosometh

go - 什么是使用 goroutine 的正确方法?

我需要对每个请求应用一些测试,并根据测试结果触发响应。如果其中一个测试失败,我需要立即发送响应,否则我会等待所有测试成功完成。我想以并发方式进行该测试。现在,我这样做(简化):funchandler_request_checker(whttp.ResponseWriter,r*http.Request){done:=make(chanbool)quit:=make(chanbool)counter:=0goTestOne(r,done,quit)goTestTwo(r,done,quit)..............goTestTen(r,done,quit)for{select{ca

go - 使用 golang channel 的结果不一致

我用Go编写了一个任务,用于从一堆文本文件中获取唯一列表。我使用channel进行了一些并行化,现在结果不一致-每次使用相同的输入文件输出/不输出5条记录的差异。我正在用gorunprocess.go|测试它wc-l在Fedorax86_64、go1.1.2、8核amd上。代码是:packagemainimport("fmt""os""io""encoding/csv""regexp""log")var(cleanRe*regexp.Regexp=regexp.MustCompile("[^0-9]+")commarune='\t'fieldsPerRecord=-1)funcclea

go - 使用 goroutins 和 channel 的并发有限消费者

我试图重现“管理资源的方法是启动固定数量的handlegoroutines,所有这些goroutines都从请求channel读取。”来自EffectiveGo并找到了fatalerror:allgoroutinesareasleep-deadlock!想法很简单:有1个队列和1个结果channel以及几个数量有限的“worker”。我的密码是inGoPlaygroundqueue:=make(chan*Request)result:=make(chanint)quit:=make(chanbool)goServe(queue,quit)fori:=0;i函数服务:funchandle