草庐IT

channel_id

全部标签

dictionary - Golang 多个计时器与 map+channel+mutex

所以我正在使用map/channel/mutex实现多个计时器。为了取消计时器,我有一个存储取消信息的channel映射,下面是代码:vartimerCancelMap=make(map[string]chaninterface{})varmutexLockersync.MutexfunccancelTimer(timerIndexstring){mutexLocker.Lock()defermutexLocker.Unlock()timerCancelMap[timerIndex]=make(chaninterface{})timerCancelMap[timerIndex]现在这个

google-app-engine - 使用 GO 在 appengine 上调用 channel.Create 时出错

我正在使用ChannelApiGoReference中的示例代码.当我运行时,出现以下错误:channel.Create::调用错误1:调用/channel.CreateChannel没有注册我找不到任何引用资料。有人知道吗? 最佳答案 根据https://groups.google.com/forum/#!topic/google-appengine-go/cetKWCkoHfg这是AppEngine运行时中的一个已知错误:http://code.google.com/p/googleappengine/issues/detail

转到 : channel is necessary in this case?

http://play.golang.org/p/Xn3Qw7xAi3很难理解channel。我有funcmain(){in:=make(chanint)out:=make(chanint)goQuickSort(in,out)fori:=0;i这使得名为in、out和goroutine的两个channel成为函数Quicksort。1.QuickSort如何将in和out作为参数?它是否从下面的线路接收?in2。这种情况下使用channel是最佳的吗?动态地接收值看起来非常整洁……如果没有channel进行排序会有什么不同?这种情况更快? 最佳答案

go - 通过来自 channel 值的指针分配给局部变量

代码在这里:http://play.golang.org/p/WjpgN_0AaP在第45、46和47行,有三种不同的方法可以从消息代理中提取值(value)。//varmbMessageBroker=*所有这三个都具有完全相同的结果。选择一种方式而不是另一种方式有什么意义?另外,我很困惑为什么星号看起来没有什么区别。 最佳答案 查看函数声明:func(c*MyGui)Receive(in我们可以看到会给你一个*MessageBroker类型的值,指向MessageBroker的指针结构。在指针值之前放置一个星号将取消引用它(参见G

logging - Logger.SetPrefix() 是否作为上下文粘在 channel /线程之间?

当我使用其他语言的日志包时,我总是强制执行某种类型的上下文Guid(UUID),每次调用记录器时都会记录下来。具体来说,这确实有助于在记录1000多个请求时跟踪哪组日志属于哪个Web请求或单个线程。我正在尝试使用Go附带的标准记录器来执行此操作。typeContextstruct{Log*log.Logger}//NewContextconstructsanewcontext.funcNewContext(r*http.Request)(*Context,error){id,err:=newUUID()iferr!=nil{log.Printf("ERRORinnewUUID():%s

go channel capacity 为什么比我指定的多了一个元素

packagemainimport"fmt"import"time"funcmain(){message:=make(chanstring,1)//nobuffercount:=3gofunc(){fori:=1;i输出是sendmessagesendmessage[waitfor3sec]message1sendmessagemessage2message3如果我将message:=make(chanstring,1)//nobuffer更改为message:=make(chanstring,2)//nobuffer我得到了sendmessagesendmessagesendmess

html - 使用 goQuery 按 id 搜索标签

我想使用Go检索具有特定ID的所有标签。显然,最简单的方法是使用goquery。假设我正在网站site中寻找ID为MyTag的ul标签。我想列出这样一个ul中包含的所有li。我以前从未使用过jQuery,所以感觉有点迷茫。resp,_:=http.Get(site)httpBody:=resp.Bodynode,_:=html.Parse(httpBody)document:=goquery.NewDocumentFromNode(node)document.Find("ul.MyTag").Each(func(iint,ul*goquery.Selection){//MyTagwil

go - 我如何向 channel 发送者发出信号以退出 golang?

我在Go中使用channel来处理各种数据管道。代码看起来像这样:typeChannelsstruct{inputschanstringerrcchanerrorquitchanstruct{}}func(c*Channels)doSomethingWithInput(){deferclose(c.quit)deferclose(c.errc)forinput:=rangep.inputs{_,err:=doSomethingThatSometimesErrors(input)iferr!=nil{c.errc这似乎是一种在channel处理器之间传递退出信号的合理方式,并且基于thi

select - golang : channel in select statement is only receiving sometimes (? ??)

我在从两个channel接收的go例程中有一个select语句。for{fmt.Printf("Waitingforselectstatement...\n")select{casereq:=如果调用函数两次发送到第一个channel然后发送到第二个channel一切正常:requestChan控制台输出(正确)是:>Waitingforselectstatement...>Igotarequest:{Loginyaylaswiese}>Waitingforselectstatement...>SendingtruetothedoneChannel>Igotarequest:{Sign

go - 关闭 channel 与发送例如空结构?

我有一个由channel连接的goroutines的管道,这样每个goroutine都会触发另一个goroutine,直到所有goroutine都运行完。更简单地说,想象两个goroutinesA和B这样当A完成时它应该告诉B它可以跑。它工作正常,我尝试了一些变体,因为我对pipelinesinGo有了更多了解。.目前我有一个信令channelch:=make(chanstruct{})goA(ch)goB(ch)...B阻塞funcB(ch和A完成后关闭funcA(chchanstruct{}){deferclose(ch)...}这很好用,我也尝试过在A()中发送一个空结构stru