草庐IT

while循环

全部标签

go - 在带有闭包的循环中生成 go 例程

我有一个字符串列表,其中可以包含1到100,000之间的元素数。我想验证每个字符串,看看它们是否存储在数据库中,这需要调用网络。为了最大限度地提高效率,我想为每个元素生成一个goroutine。目标是如果go例程函数内部的验证之一返回err,则返回false,如果没有err,则返回true。因此,如果我们发现至少一个err,我们就可以停止,因为我们已经知道它将返回false。这是基本思路,下面的函数是我目前一直在考虑使用的结构。我想知道是否有更好的方法(也许使用channel?)。for_,id:=rangeuserIdList{gofunc(idstring){user,err:=v

go - For 循环以其主体结束

For循环以其主体结束,不再继续我需要找到wIndex,检查它是否在slice中,如果没有添加值我哪里出错了?varxmake(map[int]float32,10)vars[]intvarvalue=100fori:=1;i 最佳答案 您从一个空的sslice开始。因此,您永远不会进入向slice添加元素的内部for循环。这是另一种直接的方法:fori:=1;i请注意,您需要将值转换为float32,因此x[wIndex]+=float32(value)而不是x[wIndex]+=valuerand.Intn(nint)生成[0,

Golang for select 循环消耗 100% 的 cpu

我有一个资源需要在允许任何访问之前加载。它还需要每分钟更新一次。channel的长度为1struct{},所以如果资源还没有加载,循环就会被阻塞。下面这段代码开始使用我100%的cpu,我尝试添加time.Sleep(10*time.Millisecond)这使得应用程序的cpu消耗下降到1%我认为自动收报机是定时收集的更好选择。为什么它会消耗100%的CPU或任何更好的实现想法?func(al*AsyncLoop)Run(){gofunc(){for{select{case 最佳答案 default语句创建一个导致100%cpu使

performance - for循环速度比较

我想知道Go中的len运算符有多快,因此我编写了一个简单的基准测试。我的期望是,通过避免在每次循环迭代期间调用len,代码会运行得更快,但事实恰恰相反。这是基准:funcsumArrayNumber(input[]int)int{varresintfori,length:=0,len(input);i结果如下:goos:windowsgoarch:amd64BenchmarkSumArrayNumber-83000000004.75ns/opBenchmarkSumArrayNumber2-83000000004.67ns/opPASSokcommand-line-arguments4

戈朗 : why does the word "hello" loop 5 times while the word "world" loops only 4?

这个问题在这里已经有了答案:Nooutputfromgoroutine(3个答案)关闭7年前。packagemainimport("fmt""time")funcsay(sstring){fori:=0;i运行代码,输出为:helloworldhelloworldhelloworldhelloworldhello在前4个循环中,每100毫秒,将打印一个“hello”,然后打印一个“world”。并且在最后一个循环中只会打印一个“hello”。有没有人可以解释一下代码的执行顺序是什么?

go - conn.Read 在通过其他 go 例程关闭 conn 时进入无限循环

我的代码有点复杂,但简单来说,它有多个go例程,所有都调用不同的TCP服务器,并在流中出现可读消息时在for循环中读取输入。到目前为止,一切都很好。现在有另一个go例程来管理之前的一堆“客户端”并在用户需要时关闭它们。为此,我将每个“conn”与适当的goroutine客户端相关联并关闭它。我面临的问题是,只要我调用任何conn对象的close函数,其对应的Read函数就会进入无限循环,不断读取空字符串。我写了一个简单的代码,类似于我在多个go例程中处理连接的方式-https://play.golang.org/p/wq7zt9Kqz7长话短说简而言之,我有一个“类”,它代表一个远程服

go - golang 中的嵌套循环

我有两个数组:Cart和Promotions,我需要找出哪些促销可以应用于购物车。促销由Affectee和Affected组成,所以我所做的是在我的购物车数组中搜索以查看我是否有任何Affectee,如果有,那么我将搜索任何Affected,然后应用促销。然而,这迫使我实现三个嵌套循环,这对于具有3秒超时的API来说并不理想。我想知道golang的数组是否有一些东西,或者是否有办法让它更快这是我的代码:OUTER:fori,item:=rangecartSession.Cart{for_,promo:=rangepromotions{ifitem.Name==promo.Affecte

for-loop - 在 golang 中写 while (for) 的更好方法

我正在研究一个while循环,它是Go中的一个for,如下面的代码ele=path.Dir(str)forele!="."{functionA()ele=path.Dir(ele)ifele=="."{functionA()functionB()}}在上面的代码中,您可以看到我根据while(for)中的条件调用了functionA两次有没有更好更简洁的方法来做到这一点? 最佳答案 这是执行相同任务的稍微不同的方式。更新:更新了答案以反射(reflect)新要求。ele:=path.Dir(str)ifele=="."{return

go - 为什么我有一个死锁,即使它包含一个无限循环?

我已经开始摆弄Go,并且对go例程着迷。我现在编写了一个简单的测试,看看我是否可以在连续打印变量的同时更改它的值。我现在有以下代码:packagemainimport("fmt""time")funcchange(cchanfloat64)float64{time.Sleep(2*time.Second)return2.5}funcmain(){s:=1.1c:=make(chanfloat64)gochange(c)s=不幸的是它以错误结束:fatalerror:allgoroutinesareasleep-deadlock!goroutine1[chanreceive]:main.

go - 输出反向链表时出现无限循环

我正在学习Go并编写了以下代码来反转链表。但是,代码没有按预期工作。这是一个节点结构以及用于打印和反转列表的函数。typeNodestruct{numberintprevious*Nodenext*Node}funcPrintList(node*Node){forn:=node;n!=nil;n=n.next{fmt.Println(n)}}funcReverseList(node*Node){varnextNodeRef*Nodeforn:=node;n!=nil;n=n.previous{ifn.next==nil{n.next=n.previousn.previous=nil*n