jjzjj

goroutine

全部标签

Mongodb 对例程的查询会产生巨大的堆栈跟踪

我正在对go程序中的api进行大量网络调用,结果存储在数据库中(使用mgo)。api调用是在单独的go例程上完成的。在其他例程中,我会在更新数据库之前从数据库中提取信息并对其进行处理。当数据被放回时,会设置一个标志,以便知道该数据已经过后处理,因此当程序向数据库请求另一个条目以进行后处理时,数据库会返回一个标志complete设置为false。当标志设置为true时,go例程将关闭:wg.done()。一切都很好,我有很多打印输出告诉我程序是如何进行的,但是在运行结束时我得到一个包含很多相同内容的巨大堆栈跟踪:goroutine56731[sleep]:time.Sleep(0x12a

Goroutines 没有遍历 slice

我有这个代码:for_,v:=rangesams{sam:=vpid:=getPracticeIdBySam(db,sam)gofunc(){deferwg.Done()for_,v:=rangepid{process(db,stmt,v,min_year,max_year,bar)}}()}它遍历第一个“pid”,但它停在那里。这是有原因的吗? 最佳答案 我找到了原因。这是因为我在process中有wg.Wait()导致它挂起。 关于Goroutines没有遍历slice,我们在Sta

go - channels如何均匀分配给多个goroutines

这个问题在这里已经有了答案:Multiplereceiversonasinglechannel.Whogetsthedata?(4个答案)关闭7年前。我有这段代码可以在任何给定时间上传最多30个文件(可能需要上传数千个文件)。一切都像我想要的那样工作:goroutines从任务中获取一个文件,上传它,然后到下一个。我的问题是:为什么goroutine不上传相同的文件?我已经对此进行了测试,似乎一个文件从未上传过两次。这些channel是否在进行循环?tasks:=make(chanstring,10000)varwgsync.WaitGroup//createalimitednumbe

networking - 尝试在 go 中实现端口扫描器

我最近开始学习围棋。唯一的原因是goroutine似乎只存在于这种语言中(我有java背景,老实说,永远不会完全切换到go)。我想实现一个简单的端口扫描器,它可以在给定的网络范围内找到每个http服务器(打开端口80的主机)。以下是我的做法:packagemainimport("net""fmt""regexp""strconv""time")//nexttwofunctionsareshamelesslycopiedfromsomewherefuncip2long(ipstrstring)(ipuint32){r:=`^(\d{1,3})\.(\d{1,3})\.(\d{1,3})\

Go logging struct 实例化实用方法的 Goroutine 线程安全

我正在使用一个新的go服务,我有一个SetupLogger实用函数,它创建一个新的go-kit日志结构实例log.Logger。从在单独的go-routines中处理请求的代码调用此方法是否安全?packageutilsimport("fmt""github.com/go-kit/kit/log""io""os""path/filepath")//Iftheenvironment-specifieddirectoryforwritinglogfilesexists,opentheexistinglogfile//ifitalreadyexistsorcreatealogfileifno

go - goroutine 的变量

我目前正在使用Go制作一个网络应用程序。我想在我的模板上知道用户何时登录,我目前正在使用这种方法进行登录response:=&viewCharacter{true}template.Renderer.ExecuteTemplate(w,"character_search.html",response)如您所见,我正在传递一个仅包含boolLogged的​​viewCharacter结构,然后在模板上我可以执行以下操作{{if.Logged}}有没有其他方法可以做到这一点?而不是在每个模板上传递一个记录的bool值?也许可以为http处理程序的每个goroutine设置一个变量来保存用户

go - 为什么 goroutine 中的 fmt.Println 不打印一行?

我有以下代码:packagemainimport"net"import"fmt"import"bufio"funcmain(){conn,_:=net.Dial("tcp","irc.freenode.net:6667")reader:=bufio.NewReader(conn)gofunc(){str,err:=reader.ReadString('\n')iferr!=nil{//handleitfmt.Println(err)}fmt.Println(str)}()}如果我没有从goroutine中的缓冲区读取的代码,它会输出这样的消息,这是我期望发生的情况::zelazny.f

戈朗 : calculate how many goroutines are started by worker itself?

这是我的问题:调用者将创建多个goroutines来运行我的代码doWork,gofunc(){fordata:=rangedataSet{doWork(data)}}()现在,我想统计有多少goroutines开始做这项工作,尽管我不能修改或读取来自调用者的数据。我怎样才能做到这一点?[update]doWork传递给调用者,例如:doWork:=func(iint){testArray[i]++...}Parallelize(workerNumber,doWork)所以我打算使用一个全局变量作为计数器。 最佳答案 runtime

Go程序陷入僵局

这是我正在使用的Golang程序,只是为了让我的概念正确。当我运行程序时它陷入僵局我不明白为什么?请任何人指出出了什么问题?packagemainimport("fmt""sync")varwgsync.WaitGroupfuncmain(){numOfGoRoutines:=10wg.Add(numOfGoRoutines)ch:=make(chanint,numOfGoRoutines)fori:=0;i输出为:warning:GOPATHsettoGOROOT(C:\\Go)hasnoeffectgo-9go-0go-1go-2go-3go-4go-5go-6go-7go-8fa

go - 使用 channel 在 Go 中处理事件

我写了一个SDK,封装了一堆逻辑和功能。通常,我会使用事件监听器/回调向使用SDK的应用程序提供反馈,但这在Go中不是惯用的。据我所知,channel和goroutines填补了回调的空白,但实现它的方法是什么?例如,我的SDK有许多事件要通知主应用程序。我会使用一个基于Event结构的channel吗?此Event将包含一个指定事件类型的_type字段,然后是interface{}类型的data字段类似于Java中的Object。然后接收方将检查类型并相应地转换数据。无论是上述方法还是一个事件channel,应用程序都会监听它所关注的任何channel。郑重声明,我更喜欢前一种方法,