第六天:golang学习笔记之time

★time | time包提供了时间的显示和测量用的函数.

time

time包提供了时间的显示和测量用的函数.

time包提供了最基本的时间计量结构Time,Duration,Location

时间打印格式如下:
2019-12-18 21:45:32.987483681 +0800 CST m=+0.000048086
年-月-日 小时:分钟:秒.纳秒 时区 m=+xxx.xxxxxxx

  • UTC:协调世界时(Universal Time Coordinated),UTC相当于本初子午线(即经度0度)上的平均太阳时,北京时间比UTC时间早8小时
  • CST:CST可能就是北京时间?China Standard Time
  • m=+xxx.xxxxxxx:这里的xxxxxxx为与程序执行开始时间的时间偏移,纳秒粒度

Time

Time不应使用指针去传递,结构如下:

type Time struct {
    // 用了两个变量去储存时间,一个存秒,一个存纳秒
    // 注释还解释了储存方法
    wall uint64
    ext  int64

    // 用来表示时区,`loc==nil`代表UTC时区
    loc *Location
}

Timer注释长的一批,总体思想如下:

  • 精度是纳秒
  • Time应该用值传递去储存而不是*Timer
  • 有几个方法不是并发安全的:GobDecodeUnmarshalBinaryUnmarshalJSONUnmarshalText
  • 不要用 == 运算符去比较时间,因为此运算符会去比较Location是否相同,总之用Time自带方法就OK

看完了注释来康一下可以返回Time对象函数吧:

  • func Unix(sec int64, nsec int64) Time
  • func Date(year int, month Month, day, hour, min, sec, nsec int, loc *Location) Time
  • func Parse(layout, value string) (Time, error)
  • func Now() Time

Duration

定义如下:

type Duration int64

粒度为纳秒,最长表示时间290年

Location

定义如下:

type Location struct {
    name string
    zone []zone
    tx   []zoneTrans
    // 一丢丢注释
    cacheStart int64
    cacheEnd   int64
    cacheZone  *zone
}

time包提供了两种计时器Timer和Ticker

Timer

顾名思义,计时器,经过一段时间间隔后触发[1],类似于JS中的SetTimeout()。通过func NewTimer(d Duration) *Timer 函数返回Timer对象指针,其结构如下:

type Timer struct {
    C <-chan Time
    r runtimeTimer
}

这里触发的意思即,到达时间后Timer.C这个通道不再阻塞,所以可以通过<-time.NewTimer(5*time.Second).C将程序在此阻塞5秒,5秒过后通道被写入当前的时间对象Time(Time对象,不是Timer),若Timer不活跃将一直阻塞。
Timer的可用方法如下:

  • func (t *Timer) Reset(d Duration) bool:复用当前Timer,返回Timer在Reset前是否活跃
  • func (t *Timer) Stop() bool:停止当前Timer,返回Timer在Stop前是否活跃

PS:After(d Duration) <-chan Time是一种封装好的更简单的用法
PS:AfterFunc(d Duration, f func()) *Timer是一种回回调式的用法,将runtimeTimer的f改写为goFunc,并将func注册刀arg中,意为时间到后go arg.(func())(),即开协程运行func

Ticker

这里的Ticker中文意思为“滴答”,指的是周期性的发出滴答的声音,即定期触发,类似于JS中的SetInterval()。通过func NewTicker(d Duration) *Ticker函数返回Ticker对象指针,其结构如下:

type Ticker struct {
    C <-chan Time // The channel on which the ticks are delivered.
    r runtimeTimer
}

和Timer结构很类似,两者的差别就是Ticker在初始化时会额外对runtimeTimer结构体的period字段赋值int64(d),意为周期执行。
另外Timer没有Reset函数,使用Stop函数同样会让Ticker停下。这时候Ticker就会永久阻塞(我觉得应该是这样)
PS:Tick(d Duration) <-chan Time是一种封装好的更简单的用法

PPS:func Sleep(d Duration)是一个与上两种相似用处但功能更简单的函数,不会返回当前时间

你可能感兴趣的:(第六天:golang学习笔记之time)