草庐IT

cpu-time

全部标签

go - 我如何从 time.Now() 函数中获取分钟和小时

关闭。这个问题是notreproducibleorwascausedbytypos.它目前不接受答案。这个问题是由于错别字或无法再重现的问题引起的。虽然类似的问题可能是on-topic在这里,这个问题的解决方式不太可能帮助future的读者。关闭3年前。Improvethisquestion我正在做一个检查程序,我需要以分钟为单位的实时时间,比如如果是10:00,我应该有600分钟我尝试使用time.Now()函数以及.Hour和.Minute并且它有效但遗憾的是当涉及到ParseDuration来获取小时数时我得到这些错误:go:91:4:赋值不匹配:1个变量但time.ParseD

time - 两个持续时间的乘积在 Golang 变量中为零

在下面的Golang代码中,两个持续时间的乘积在变量“delay”中为零很奇怪,但是当不通过任何变量直接打印乘积时,输出符合预期。任何人都可以解释这个吗?funcStartCleanTask(){gofunc(){delay:=cfg.Config.Timeout*time.Secondfor{fmt.Println("Gocleantask:",delay,cfg.Config.Timeout*time.Second)select{case输出是:Gocleantask:05m0s更新:我还尝试运行以下代码,它运行良好。packagemainimport"fmt"import"tim

go - 在 "for {select }"结构中添加一个简单的 fmt.Println 后,CPU 使用率有很大不同,为什么?

遇到困惑的情况:假设我们有一个用Go编写的for{select}函数。下面是代码:packagemain//import"fmt"funcmain(){for{select{default:_=11.firstsituation//fmt.Sprint("aa")2.secondsituation}}}而在第一种情况下,杯子的使用情况如下所示:在第二种情况下,CPU使用情况如下所示:我猜fmt.Println中发生了一些事情。可能跟Go的fmt实现机制有关?不太清楚使用所有CPU是如何发生的?提前致谢! 最佳答案 我的猜测:在第一个

windows - 可以不 Hook 所有可用的 CPU 电源吗?

我知道,大多数go的初学者都会问如何拥有可执行的go-routines/concurrency,这一点我几周前就通过了。:-)我有一个真正快速的转码器,它使用我的4+4(i7HT)CPU的每个可用周期。它将文件读入一片指向结构的指针,对这些进行计算并将结果写回磁盘。我正在使用bufio。我来自VB,所以Go的性能令人难以置信。我尝试添加最少的sleep(通过time.Sleep()),但这大大降低了性能。虽然我的转码器正在工作,但整个系统都滞后了。我必须将go任务的优先级更改为低或空闲才能再次工作。我怎样才能实现让系统保持响应的东西?现在我启动了数千个go-routines(在一片指针

algorithm - 不能在 time.AfterFunc 的参数中使用(属于)类型 func() 的函数

如果不遇到几个嵌套函数问题,我不知道如何解决这个Go算法问题。其中之一是,“不能在返回参数中使用func文字(类型func())作为类型func()字符串”。我现在使用的解决方案是://Writeafunctionthattakesin2numbers(a,b)andafunction.//Itshouldexecutethefunctionafteramilliseconds,//andthenexecutethefunctionagainafterbmilliseconds.packagemainimport"time"funcnewFunc(bint,fnfunc()string

function - 如何将 time.Duration 类型传递给 go 函数?

我正在学习GOLANG,尤其是它的并发能力。已尝试进一步开发worker_pool示例之一,以便每个工作人员都收到一个作业ID和一个作业负载,以作业的随机持续时间表示。time.sleep命令使用持续时间来等待分配的纳秒数,这是随机计算的。代码看起来像这样......//worker_poolimprovedexamplepackagemainimport"fmt"import"time"import"math/rand"//Here'stheworker,ofwhichwe'llrunseveral//concurrentinstances.Theseworkerswillrecei

go - 如果没有进一步的语句要执行,为什么 time.Sleep 不起作用?

我正在尝试运行下面这段代码packagemainimport("fmt""time")funcmain(){time.Sleep(time.Millisecond*6000)fmt.Println("Done")}正如预期的那样,它等待6秒,打印“完成”然后退出但是如果我删除打印语句,packagemainimport("time")funcmain(){time.Sleep(time.Millisecond*6000)}它不会等待并立即退出。为什么?因此,请看下面的代码packagemainimport("fmt""time")funcmain(){c:=make(chanint)g

戈朗 : Wait x amount of time before looping again without starting new goroutine

我有一个循环,需要等待一段随机时间才能再次循环。我有什么:for{rand.Seed(time.Now().UnixNano())r:=rand.Int()//Dostufft,_:=time.ParseDuration(string(r)+"ms")time.Sleep(t)}不幸的是,循环会运行多次,就像time.Sleep不工作一样。 最佳答案 您应该检查当前从t,_:=time.ParseDuration中丢弃的错误:您传递给Sleep的time.Duration处于零值,这会导致函数休眠0纳秒。更改#1:处理错误t,err

time - 如何仅使用 time.After 编写我自己的 Sleep 函数?

我正在尝试使用Go中的time.After编写自己的sleep函数,等同于time.Sleep。这是代码。第一次尝试:funcSleep(xint){msg:=make(chanint)msg:=第二次尝试:funcSleep(xint){time.After(time.Second*x)}两者都返回错误,有人可以向我解释如何使用time.After编写等同于time.Sleep的sleep函数吗?如果可能的话,我什么时候使用channel? 最佳答案 time.After()返回给你一个channel。在指定的持续时间后,将在ch

Go time.Tick 与 time.NewTicker

我是Go的新手,最近才开始学习。我遇到过自动收报机和计时器。在代码中,我们可以通过两种方式创建代码throttler:=time.Tick(time.Millisecond*50)除了语法之外,它们之间还有什么区别? 最佳答案 来自time.Tickdocumentation:TickisaconveniencewrapperforNewTickerprovidingaccesstothetickingchannelonly.WhileTickisusefulforclientsthathavenoneedtoshutdownthe