草庐IT

print_sleep

全部标签

time - 为什么 sleep 似乎在 goroutine 中不起作用

packagemainimport("fmt""time")funcmain(){c:=make(chanstruct{})count:=1gofunc(){for{fmt.Println("foo",count)count++time.Sleep(2)}c这是我的代码,我发现它并没有在每个循环中休眠2,并快速打印出来。这是什么原因呢?我搜索的是sleep会让goroutine放弃对cpu的控制权,当它再次获得控制权时会检查自己是否正在休眠? 最佳答案 time.Sleep拿它的Duration以纳秒为单位,所以延迟2秒应该是;ti

printing - 使用 bytes.replace 时有没有办法使用通配符?

我正在用Go编程,我读取了一个文本文件,我替换了其中的多个内容,将代码从一种语言翻译成Go以便能够运行。我遇到的问题是,当尝试替换Println语句之类的东西时,如果不真正特定于我正在转换的代码,我就无法在语句末尾得到括号。有没有办法使用这样的代码?src=bytes.Replace(src,[]byte("Insert"),[]byte("Println("*")"),-1)并且能够在代码行的末尾放置一个括号? 最佳答案 packagemainimport("fmt""regexp")funcmain(){src:=[]byte(

go - channel 关闭但所有 goroutines 都在 sleep - 死锁

是的,它看起来像是StackOverflow上最重复的问题之一,但请花几分钟时间回答这个问题。func_Crawl(urlstring,fetcherFetcher,chchan[]string){ifstore.Read(url)==true{return}else{store.Write(url)}body,urls,err:=fetcher.Fetch(url)iferr!=nil{fmt.Printf("notfound:%s\n",url)}fmt.Printf("found:%s%q\n",url,body)ch我将在循环结束后关闭channel。该程序返回正确的结果但在最

go - 为什么 time.Sleep(2) 不能与 go routines 一起工作?

来自此处的例程示例:https://gobyexample.com/goroutines,为什么用time.sleep(2)替换fmt.Scanln代码不起作用?如果将最后三行替换为time.Sleep(2),则go例程不会打印任何内容。funcmain(){f("direct")gof("goroutine")gofunc(msgstring){fmt.Println(msg)}("going")time.Sleep(2)} 最佳答案 time.Sleep需要time.Duration作为参数,以纳秒为单位。如果你想要秒,使用ti

shell - 如何将 fmt.Print 和 log.Print 保存到 Golang 中的同一个文件中

在shell中,我使用gorunfile>output,但只有fmt.Print被保存到输出中。所有的log.Print依然输出到屏幕!并且在网上搜索后,我发现我可以为日志设置输出目录,但是如何将日志和fmt保存在同一个文件中? 最佳答案 记录器写入STDERR,而fmt.PrintXXX函数写入STDOUT。你有两个选择:1)捕获STDERR到文件中。Bash类shell使用:gorunfile>output2>&12)设置记录器的Output至os.Stdout然后你像正常一样运行gorunfile>output并且记录器和fm

Golang 标志库 : Unable to override Usage function that prints out command line usage

我正在开发一个简单的命令行工具,但我发现默认的Usage消息有点欠缺。我想定义我自己的,我认为我做对了我指的是thisexample.我注释掉了我编写的大部分代码,因此包含main函数的文件现在看起来像这样:packagemainimport("flag""fmt""os")funcmain(){//setthecustomUsagefunctionsetupFlags(flag.CommandLine)//defineflags...//thenparseflagsflag.Parse()//customcodethatusesflagvalues...}funcsetupFlags

go - 这个 Go print 语句的顺序是什么?

我正在学习关于Golang和这段代码的“GO之旅”教程:packagemainimport("fmt""math")funcpow(x,n,limfloat64)float64{ifv:=math.Pow(x,n);v=%g\n",v,lim)}//can'tusevhere,thoughreturnlim}funcmain(){fmt.Println(pow(3,2,10),pow(3,3,20),)}会打印“27>=20920”。我很困惑为什么不是“927>=2020”不应该第一次调用pow(3,2,10)返回9,打印它,然后调用pow(3,3,20)并打印其余的吗?

go - time.Sleep() 是否屈服于其他 goroutines?

在Go中,对time.Sleep()的调用会产生给其他goroutines吗?我有一种感觉,但在其他答案中(例如:Understandinggoroutines)time.Sleep没有明确列为调度点。 最佳答案 是的。参见Pre-emptioninthescheduler.Inpriorreleases,agoroutinethatwasloopingforevercouldstarveoutothergoroutinesonthesamethread,aseriousproblemwhenGOMAXPROCSprovidedon

unit-testing - 如何在golang中测试 sleep 功能

我自己写了sleep函数,想测试一下。以下是我的代码:funcTestSleep(t*testing.T){start:=time.Now()mySleepFunction(65)end:=time.Now()if(end-start)!=65{t.Error("Incorrectsleepfunction")}}这是行不通的。我正在尝试获取开始时间和结束时间,然后将其与预期时间进行比较。预期时间将以秒为单位。我尝试了end.Sub(start),但这返回了类似1m30.0909的内容,结果我需要90。如果有人可以帮助我,那就太好了。谢谢:) 最佳答案

戈朗 : how to print data from running goroutine at fixed intervals?

我在理解golang中的channel时遇到了一些问题。据我所知,channel是在给定时间间隔内将数据发布到控制台的正确方式。假设我有一个正在工作的goroutine,然后在我的主循环中我想每秒从那个goroutine打印数据。如何编写这样的代码?一个简单的例子将不胜感激。 最佳答案 您可以在内存中拥有一些protected共享状态,您可以从长时间运行的进程中更新这些状态。然后你有一个计时器每秒触发一次共享状态检查。这是一个简单的例子:http://play.golang.org/p/gfGvhHUWIc代码:packagemai