草庐IT

notification-channel

全部标签

golang,goroutines,如何在另一个 channel 中设置 channel ,然后在关闭母 channel 后阅读

我是Golang的新手,但正在努力理解这门伟大的语言!请帮帮我..我有2个channel。“进”和“出”channelin,out:=make(chanWork),make(chanWork)我设置了在chanel中监听的goroutinesworker,捕获工作并完成它。我有一些工作,我会寄给香奈儿。当Work由worker完成时,它会写入Outchannel。funcworker(in当所有工作完成后,我会在程序写入时关闭两个channel。现在我想在OUTchannel中写完成工作的结果,但是在某些部分中将所有内容分开,例如,如果工作类型是这样的:typeWorkstruct{D

Go channel 缓冲和死锁

考虑以下代码块,预计会因达到缓冲区限制而引发错误:packagemainimport("fmt""time")funcmain(){burstyLimiter:=make(chantime.Time,4)fori:=0;i但是当我用下面的代码尝试确切的block时,它会阻塞而不是抛出错误。我很想了解这种行为。感谢您的宝贵时间。packagemainimport("fmt""time")funcmain(){requests:=make(chanint,5)close(requests)limiter:=time.Tick(time.Millisecond*200)forreq:=ran

go - 我如何等待 channel 事件的间歇来触发某些事情?

我有一个channel,它将接收对它的突发写入。我想等到channel上的突发发送完成后再触发操作。我看过这个gist,但是,如果缓冲区中有数据,它将每隔interval发送一次输出:funcdebounceChannel(intervaltime.Duration,outputchanint)chanint{input:=make(chanint)gofunc(){varbufferintvarokbool//Wedonotstartwaitingforintervaluntilcalledatleastoncebuffer,ok=在我的例子中,我想等到输入channel上不再有任何

go - 使用 Go channels 加速 for 循环

我正在尝试使用Go的并发来加速我的代码,这是我所拥有的:fori:=7;i>-1;i--{gofunc(chchanint32,ch2chanint32,iint,arxint32,aryint32,dirf[]int8,dirg[]int8){nx:=arx+int32(dirf[i])ny:=ary+int32(dirg[i])ch-1;i--{nxx:=运行此命令后,我没有得到预期的矩阵slice,它全是零。但是如果我运行下面的代码,它会像没有channel的代码一样给出矩阵slice,但是它太慢了。fori:=7;i>-1;i--{gofunc(chchanint32,ch2c

go - 同时将映射条目读取到 channel 中

我有一个场景,我需要遍历(尽可能多的)map条目并将它们发送到一个channel中。channel另一端的操作可能需要很长时间,并且map是并发访问的(并受RWMutex保护)。该map也相当大,我想避免创建它的临时副本。假设我有一个这样的结构:typeExamplestruct{sync.RWMutexmmap[string]struct{}}现在我想到了这样的事情:func(e*Example)StreamAll()languagespecification关于在map上进行测距有这个有趣的一点:Ifmapentriesthathavenotyetbeenreachedarerem

go - 在 Go 中通过多个 channel 广播一个 channel

我想将从一个channel接收到的数据广播到一个channel列表。channel列表是动态的,可以在运行阶段修改。作为Go的新开发人员,我编写了这段代码。我发现它对我想要的东西来说很重。有更好的方法吗?packageutilsimport"sync"//StringChannelBroadcasterbroadcastsstringdatafromachanneltomultiplechannelstypeStringChannelBroadcasterstruct{SourcechanstringSubscribersmap[string]*StringChannelSubscri

go - 使用 golang channel 。获取 "all goroutines are asleep - deadlock!"

我目前正在研究goroutines、channels和sync.WaitGroup。我知道waitgroup用于根据天气等待所有go例程完成wg.Done()已被调用足够多次以减少wg.Add()中设置的值。我写了一小段代码来尝试在golangPlayground上测试这个。显示如下varchannelchanintvarwgsync.WaitGroupfuncmain(){channel:=make(chanint)mynums:=[]int{1,2,3,4,5,6,7,8,9}wg.Add(1)goaddStuff(mynums)wg.Wait()close(channel)rec

go - go 中奇怪的 channel 行为

packagemainimport("encoding/json""fmt""/something/models""os""path/filepath""runtime")funcWriteDeviceToFile(dchan*models.Device,fileNamestring){_,b,_,_:=runtime.Caller(0)basepath:=filepath.Dir(b)filePath:=basepath+"/dataFile/"+fileNamevarf*os.Filevarerrerrorf,_=os.OpenFile(filePath,os.O_APPEND|o

go - Go中如何使用 channel 安全同步数据

下面是一个如何使用互斥锁来安全访问数据的例子。我如何使用CSP(communicationsequentialprocesses)而不是使用互斥锁和解锁来做同样的事情?typeStackstruct{top*Elementsizeintsync.Mutex}func(ss*Stack)Len()int{ss.Lock()size:=ss.sizess.Unlock()returnsize}func(ss*Stack)Push(valueinterface{}){ss.Lock()ss.top=&Element{value,ss.top}ss.size++ss.Unlock()}func

go - 使用 Go RabbitMQ streadway/amqp 驱动程序时无法从函数返回 *amqp.Channel

我正在尝试使用streadway/amqp连接到RabbitMQ总线Go的驱动程序。我正在处理重新连接例程,为此,我有一个rabbitMQConsume函数调用rabbitMQConnect函数。funcrabbitMQConnect(cfgobjects.GlobalConfig)(*amqp.Connection,*amqp.Channel,error){rabbitConfig:=amqp.Config{Vhost:cfg.RabbitVHost,Heartbeat:5,}//OpenconnectiontoRabbiturl:=fmt.Sprintf("amqp://"+cfg