登录
首页 >  Golang >  Go教程

去时间和它的两个时钟

来源:dev.to

时间:2024-09-28 08:57:57 448浏览 收藏

你在学习Golang相关的知识吗?本文《去时间和它的两个时钟》,主要介绍的内容就涉及到,如果你想提升自己的开发能力,就不要错过这篇文章,大家要知道编程理论基础和实战操作都是不可或缺的哦!

去时间和它的两个时钟

要计算go中的时间间隔,您可以使用

start := time.Now()
// long time consuming task
duration := time.Since(start)

但是你知道吗,go 中的 time 包实际上有两个时间,而 time.since() 实际上只测量处理时间(单调时钟),而不是真实时间(挂钟)?

例如,如果任务很长,长达一整夜,并且您的计算机进入睡眠状态。然后早上你可能会过来看看,持续时间只有4个小时,而总共已经过去了10个小时。

go 中的时间包指出

操作系统提供了“挂钟”(会因时钟同步而发生变化)和“单调时钟”(不会发生变化)。一般规则是,挂钟用于报时,单调钟用于测量时间。

在上面的示例中,它真正告诉您的是,您的程序主动运行了 4 个小时,但计算机休眠了 6 个小时,因此您总共等待了 10 个小时。如果电脑没有休眠的话,4个小时就搞定了。

那么如果你想测量wall time该怎么办呢?您可以使用 round(0) 函数。 t = t.round(0) 将删除 t 中的单调时钟。

到这里,我们也就讲完了《去时间和它的两个时钟》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于的知识点!

声明:本文转载于:dev.to 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>