草庐IT

test_channel

全部标签

go - 为什么在go routine中关闭channel会导致receiving channel收到值?

我有一个go例程,它会定期轮询每个时间间隔并执行操作。它还检查完成channel,作为结束信号,以停止轮询。gofunc(){for{select{case我意识到如果我关闭channel,它也会运行,就好像值被传递给donechannel一样,它打印出“我完成了”为什么会这样? 最佳答案 来自规范:Areceiveoperationonaclosedchannelcanalwaysproceedimmediately,yieldingtheelementtype'szerovalueafteranypreviouslysentva

go - 如何始终从 Go channel 获取最新值?

我从Go开始,现在我正在编写一个简单的程序,它从传感器读取数据并将其放入channel中以使用它进行一些计算。我现在让它工作如下:packagemainimport("fmt""time""strconv")funcget_sensor_data(cchanfloat64){time.Sleep(1*time.Second)//waitasecondbeforesensordatastartspooringinc这很好用,但传感器会生成大量数据,而我总是只对最新数据感兴趣。然而,使用此设置,它只会在每个循环中读出下一个项目,这意味着如果某个点的channel包含20个值,则只会在10秒

multithreading - 为什么基于 channel 的 Lock block ?

嗨,我正在写一个Lock使用channel,旨在锁定/解锁给定“应用程序”的操作。总体思路是,一个协程持续监听两个channel:lockCh和unlockCh.任何Lock()操作发送自制channel到lockCh,并等待从那个自制channel读取,从读取这个channel完成意味着Lock()成功。类似的过程适用于Unlock().对于监听器gorouting,它会在接受Lock()时检查“应用程序”是否已被锁定,如果是这样,它将把那个自制的channel放到等待列表的尾部。如果有人Unlock(),它会唤醒(通过向channel发送消息)下一个服务员,或者如果没有其他人在等待

go - travis-ci在使用go test时需要root权限,如何设置?

我有Go测试文件,它需要root权限才能运行它(去测试)。Travisci中如何设置?这是yml:language:gosudo:requiredgo:-tipnotifications:email:on_success:changeon_failure:always在gitpush之后,travis-cibuild使用默认配置失败。 最佳答案 在travis中你可以使用sudo所以如果你想以root权限运行你的测试,改变脚本部分:script:sudo-Eenv"PATH=$PATH"gotest./...或者如果您使用的是Mak

multithreading - 通过 golang 中的 channel 进行双向通信

我有几个函数,我希望它们以原子方式执行,因为它们处理敏感数据结构。假设以下场景:有两个函数:lock(sth)和unlock(sth),goroutine可以随时调用它们来锁定或解锁sth全局数组。我正在考虑拥有一个命令channel,以便goroutines将lock和unlock命令发送到channel中,并在channel的接收端,某种处理程序通过从channel中获取命令,依次处理lock、unlock请求。这很好,但是如果handler想要将结果发送回请求者怎么办?是否可以使用golangchannel这样做?我知道可以使用某种锁定机制,如互斥锁,但我想知道是否可以为这种用例

unit-testing - 如何获得文件夹的全局测试覆盖率

显示代码覆盖率时,gotest显示每个包的代码覆盖率(百分比)。有没有办法显示一个考虑了所有子文件夹(子包)的文件夹的摘要?我想要的是整个项目的全局代码覆盖率,一个显示文件夹和所有子文件夹的代码覆盖率的数字。 最佳答案 运行后:gotest--coverprofile=coverage.out./...运行:gotoolcover-func=coverage.out您将在结果末尾看到总百分比 关于unit-testing-如何获得文件夹的全局测试覆盖率,我们在StackOverflow上

unit-testing - 我可以使用嵌套界面模拟库代码吗?

这个问题在这里已经有了答案:HowcanImockmultipletypeswhenthesignatureofaconcretemethodreferstoanotherconcretetype,notitsinterface?(1个回答)关闭3年前。我正在尝试在我的go代码中的测试中模拟第3方库。但是我无法编译我所采用的方法。如果我想模拟T2.M2的结果,有什么方法可以使它工作,或者我可以采用另一种方法吗?packagemainimport("fmt")//TwotypesinalibrarythatIdonthavecontrolovertypeT1struct{}func(T1

go - 如何捕获 channel 死锁的异常?

我正在学习Go并致力于thislesson来自GoTours。这是我目前所拥有的。packagemainimport("fmt""code.google.com/p/go-tour/tree")//Walkwalksthetreetsendingallvalues//fromthetreetothechannelch.funcWalk(t*tree.Tree,chchanint){ift!=nil{Walk(t.Left,ch)ch如您所见,我尝试通过打印出我写入channel的值来测试我的Walk函数。但是,我收到以下错误。12345678910throw:allgoroutines

go - 如何检查 channel 是否仍在 streadway/amqp RabbitMQ 客户端中工作?

这个问题在这里已经有了答案:HowtodetectdeadRabbitMQconnection?(4个答案)关闭9个月前。我正在使用github.com/streadway/amqp对于我的程序。在重新初始化之前,我应该如何确保用于消费和/或生产的channel仍在工作?例如,在ruby​​中,我可以简单地做:bunny_client=Bunny.new({....})bunny_client.start启动客户端,ifnotbunny_clientorbunny_client.status!=:connected#re-initializetheclient如何使用streadway

multithreading - App Engine Channel API 的线程安全/原子性

当我尝试使用GoogleAppEngine的ChannelAPI从两个或多个goroutines和/或任务队列发送消息时会发生什么?例如gochannel.Send(context,clientID,"Hello")gochannel.Send(context,clientID,"World")我知道在GAEGo中,所有goroutines都被多路复用到一个线程上。然而,这仍然允许在I/O期间进行抢占,并且channel发送可能符合I/O的条件。GAE开发服务器似乎序列化了所有请求,所以我没有看到任何channel发送重叠。生产服务器似乎允许一些请求并发,但channel发送看起来是原