草庐IT

goroutines

全部标签

使用 for 循环和匿名函数进行并发时出现意外行为

我已经找到了一种让代码按照我想要的方式运行的方法,但我想了解为什么它会这样运行,以便我对Go并发的理解有所提高。我正在测试sync.WaitGroup以等待一些goroutine完成,因为我计划以这种方式向AmazonS3进行多次上传。这是我最初的代码:funcmain(){varwgsync.WaitGroupfori:=1;i我惊讶地看到输出是:6,6,6,6,6。而不是像这样的:2,4,1,5,3。由于循环甚至没有转到6,这对我来说毫无意义。我后来将i变量作为参数传递给匿名函数然后它的行为符合我的预期。为什么会这样?我不明白。 最佳答案

sockets - 检索确切的连接 - tcp 套接字 - channel - goroutine

我正在学习Golang几天,所以我不清楚如何在函数内检索正确的连接“conn”函数处理消息对于相关消息“msg”谢谢!packagemainimport("fmt""log""net""os""encoding/json""time""bufio")typePacketstruct{PayloadPayload`json:"payload"`}typePayloadstruct{Datastring`json:"data"`}funcmain(){iflen(os.Args)!=2{fmt.Fprintf(os.Stderr,"Usage:%shostname\n",os.Args[0

go - 在使用 GOMAXPROCS = 256 运行无限循环 goroutines 时理解 golang 的调度程序

我正在玩Go,在我的20158核MacBookPro上运行go1.7.3。尝试了解runtime.GOMAXPROCS设置为其最大值(256)并启动相同数量的goroutine时goscheduler的工作原理,每个goroutine都运行一个无限循环。我的假设是goruntime会产生runtime.GOMAXPROCS数量的操作系统线程(即256个线程)并在这些线程中运行我的goroutines。我期待下面的代码打印出256个1:funcmain(){procs:=256runtime.GOMAXPROCS(procs)fori:=0;i此代码每次运行时都会打印不同数量的1。大多数

go - goroutine 没有输出

当SayHello()按预期执行时,goroutine不打印任何内容。packagemainimport"fmt"funcSayHello(){fori:=0;i 最佳答案 当您的main()函数结束时,您的程序也会结束。它不会等待其他goroutine完成。引自GoLanguageSpecification:ProgramExecution:Programexecutionbeginsbyinitializingthemainpackageandtheninvokingthefunctionmain.Whenthatfunctio

go - 为什么会导致 goroutine 创建的测量时间不同?

考虑以下应用程序,旨在测量goroutine创建延迟。假设我们使用GOMAXPROCS=2运行。packagemainimport"fmt"import"time"constnumRuns=10000typetimeRecordstruct{Tstime.TimeMsgstring}vartimeStamps[]timeRecordfuncthreadMain(donechanbool){timeStamps=append(timeStamps,timeRecord{time.Now(),"Insidethread"})done在我的服务器上,从Beforecreation到Insid

go - 实现具有多个生产者的信号量(使用 goroutines)

这一直是我存在的祸根。typeec2Paramsstruct{sess*session.Sessionregionstring}typecloudwatchParamsstruct{clcloudwatch.CloudWatchidstringmetricstringregionstring}typerequeststruct{ec2ParamscloudwatchParams}//ControlconcurrencyandsyncvarmaxRoutines=128varsemchanboolvarreqchanrequestfuncmain(){sem:=make(chanbool

go - 如何通过运行时获取真实文件名。不同goroutine中匿名函数调用的调用者

我有这个示例代码https://play.golang.org/p/c_2GECIcrW我期望getFileName会打印出类似ma​​in.go:11的内容,但我得到的是asm_amd64p32.s:1014在这种情况下,我该怎么做才能得到预期的结果?我可以存档并继续使用匿名函数吗? 最佳答案 您的期望不正确。为了便于解释,让我在这里粘贴您的代码:packagemainimport("fmt""path/filepath""runtime""time")funcmain(){getFileName(1)time.Sleep(tim

multithreading - 如何测试在 goroutine 中监视文件的函数

我有一个函数可以通过fsnotify监视certian文件并在文件更改时调用回调。如果回调返回false,则观看结束:import("github.com/golang/glog""github.com/fsnotify/fsnotify")typeWatcherFuncfunc(errerror)boolfuncWatchFileChanges(filenamestring,watcherFuncWatcherFunc){watcher,err:=fsnotify.NewWatcher()iferr!=nil{glog.Errorf("Goterrorcreatingwatcher%

go - 影响 goroutine 性能的因素

我在使用goroutine时遇到了一些奇怪的行为,请就我可能做错的事情提供建议或评论。这是我的过程:我正在使用goroutines同时执行模拟,但由于某种原因,我花费的时间随着我放入的goroutines数量的增加而增加,这使得我的模拟无法在合理的时间内完成。以下是我注意到的事情:每启动10k个goroutine,计算时间增加5秒我没有发现CPU或内存不足。然而,对于每10k个goroutines,CPU使用率只会增加一点点。例如,当我放置200k个goroutine时,CPU使用率约为70%我没有使用磁盘我在没有触发goroutines的情况下运行了模拟并且它完成得非常快,所以缓慢是

multithreading - Goroutines, channels select 语句

我在构建我的goroutines和channel时遇到问题。我的select语句在所有goroutine完成之前一直退出,我知道问题出在我发送完成信号的地方。我应该在哪里发送完成信号。funcstartWorker(okchanLeadRes,errchanLeadResErr,quitchanint,verbosebool,wg*sync.WaitGroup){varresultsProcessResultsdeferwg.Done()log.Info("Starting...")start:=time.Now()for{select{caselead:=