翔云

Just try, don't shy. 最新文章请点击
  博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理

golang 中时间差的计算

Posted on 2021-06-05 22:43  翔云123456  阅读(1471)  评论(0编辑  收藏  举报

操作系统提供两种时钟:“wall clock” 墙上时钟 和 “monotonic clock” 单调时钟,

wall clock 用于显示时间,会受到时钟同步的影响。

monotonic clock 用于计量时间,例如 时间大小比较,时间差计算。不会受时钟重置的影响。

例如,下面代码中,计算耗时,耗时一直是正的,20ms。
即使 wall clock 被重置。

start := time.Now()
... operation that takes 20 milliseconds ...
t := time.Now()
elapsed := t.Sub(start)

其他的函数,例如,
time.Since(start), time.Until(deadline), and time.Now().Before(deadline),也是一样的,不受wall clock重置的影响。

也就是说,在时间差相关计算时,需要使用 t.Sub(start), time.Since(start), time.Until(deadline), and time.Now().Before(deadline)。

参考

Package time -- Monotonic Clocks