草庐IT

while循环

全部标签

for-loop - 暂停for循环的执行

我有一个API,我也在发布一个小的JSON对象。这作为一个无限循环运行,循环7种颜色(彩虹)并将它们发送到上述JSON对象中。我正在连接的API的速率限制为每分钟40个请求。我不想达到速率限制,所以我设计了一种方法来避免这种情况;我有一个全局变量,用于存储允许我发出的请求数我有一个函数,它保存一个代码集,每60秒运行一次,并填充存储我的请求的全局变量然后我有一个永无止境的for循环,它运行并检查仍然允许发出的请求数,如果它大于0,那么我们发出下一个请求,如果不是,那么我们就休眠一秒钟再试一次看起来有点像这样:varrateLimitintfuncmain(){request:=gore

带有 for 循环的 golang channel 行为

我很好奇channel的行为以及它们与循环相关的工作方式。假设我有以下代码:消费者tick:=time.Tick(time.Duration(2)*time.Second)for{select{case我有一个goroutine具有以下内容:处理器for{select{casecanProcess:=如果消费者推送到channel的速度比处理器完成同步过程的速度快,会发生什么情况?它们是堆积起来等待处理器完成,还是跳过一个“节拍”?如果它们堆积起来,是否存在内存泄漏的可能性?我知道我可以将同步过程放在goroutine中,但这实际上是为了了解channel的行为方式。(即我的示例有一个

Golang 在另一个 for 循环中退出 bufio for 循环

我有一个初始循环,它不断询问用户问题,直到用户键入q退出。funcmain(){scanner:=bufio.NewScanner(os.Stdin)quit:=falsevarcitystringvaranythingstringforquit==false{fmt.Println("Enteracityname")forscanner.Scan(){city=scanner.Text()fmt.Printf("qtoquit(Anythingelsetocontinue):")anything=scanner.Text()}ifanything=="q"{fmt.Println(c

go - 调用 db.Ping() 时的无限循环

我正在尝试创建到数据库的基本连接。当我尝试使用db.Ping()测试连接时出现问题;一切正常,直到我到达这条线。Ping将程序发送到无限循环(函数调用永远不会返回),我不确定如何解决这个问题。packagemainimport("database/sql""fmt""html/template""net/http"_"github.com/lib/pq"}typePagestruct{NamestringDBStatusbool}const(host="localhost"port=8080user="username"password="password"dbname="GoTest

go - 如何在 Go 中对模板(不是范围)进行循环?

这个问题在这里已经有了答案:forloopintemplates(1个回答)关闭4年前。很简单,我需要在View(模板)的golang中进行循环。我无法找到关于如何做到这一点的接缝。或者如何用range做同样的事情?a:=[]int{1,2,3}fori:=1;i如何在View中执行此操作?

go - 云存储 : unable to upload any content while local with golang

我有这段代码:ctx:=context.Background()cliente,err:=storage.NewClient(ctx)iferr!=nil{log.Fatal(err)}clienteCS:=cliente.Bucket("prueba123456789")w:=clienteCS.Object("prueba").NewWriter(ctx)w.ContentType="text/plain"if_,err:=w.Write([]byte("abcde\n"));err!=nil{log.Fatal(err)}attrs,err:=clienteCS.Attrs(ct

go - 为什么 Go 对数组的范围循环有运行时开销?

我希望对数组元素进行范围迭代不会带来任何运行时开销,但它似乎比原始数组访问慢8倍:funcBenchmarkSumRange(b*testing.B){nums:=[5]int{0,1,2,3,4}forn:=0;n基准输出:BenchmarkSumRange-810000000002.18ns/opBenchmarkSumManual-820000000000.28ns/op如果它是一个长度在编译时未知的slice而不是一个数组,这可能是有意义的,在这种情况下,运行时代码必须涉及一个带有边界检查的循环。但对于在编译时已知大小的数组,考虑到开销很大,编译器可以将范围迭代替换为手动访问。

linux - 如何在字符串数组上循环

我有使用golang实现的命令行工具,它工作正常。我想执行一些应该提供字符串列表的命令apps:=$(shellfxtrunapps)apps:@echo$(apps)iscalled在终端中,我在执行make时看到以下内容(完全没问题)[app1app2]iscalled由于命令fxtrunapps返回字符串数组(varapps[]string)我的问题是如何循环apps变量?命令返回的数据很好,但现在我需要获取此列表(app1...appN)并对其进行循环,我不清楚的问题是,我如何循环遍历数组字符串?特殊情况是如果在循环列表中我得到了app7如何在代码中进行fork,例如if(ap

asynchronous - 循环结果时 Golang Chan 挂了

我对GoLangchannel还很陌生,但它并没有像我预期的那样工作。我有一个函数,我想调用3个单独的goroutines,然后等待它们全部完成。如果出现错误,我会尝试将其放在CHAN上,然后在wg.Wait()完成后处理错误。不幸的是,当循环遍历CHAN结果时它会挂起。我假设它仍在等待CHAN被填满,但并非所有goroutine都会抛出错误。处理不会始终被填充的channel循环的最佳方法是什么?我也知道我不必在这里使用CHAN,但我想确保我理解它们。下面是我的代码。funccreateWorkoutPlanForUserPreconditionCheck(planID,userID

go - 如何让每个眼镜蛇命令解析自己的标志?获取初始化循环(预期,但如何避免?)

我正在按照https://github.com/spf13/cobra#flags上的指南进行操作,但我对那里的一些内容感到困惑。我有一些服务(restapi、电子邮件服务、事件),我正在尝试做这样的事情:gorun*.gorest-envDEV-p3000gorun*.goevents-envDEV-p3001我正在关注github页面,所以我定义了我的rootCmd和restCmd:varrootCmd=&cobra.Command{Use:"myappname",}varrestCmd=&cobra.Command{Use:"rest",Short:"RESTAPI",Long: