一、time
- 默认 time.Time.String() 序列化为
2023-09-07 00:00:00 +0800 CST
- postgres 的 TIMESTAMP 类型需要
2023-09-07 00:00:00
格式,可通过 time.Time.Format(time.Date) 序列化实现
二、timer 和 Ticker
2.1 场景
- Timer用于一次性,会到达1次
- Ticker用于周期性,会到达N次
2.2 注意
注意,如果从timer.C已经收到过了,再从timer.C收就会被阻塞
所以如下前三行不是必须的,而是调用方自己应该知道是否已经从timer.C中收过数据(timer并没有提供其C内是否有数据的方法)
- 如果已经收过了,那么直接调用即可
- 如果还没收到过,那么就用下面这4行即可
if !timer.Stop() {
<-timer.C
}
timer.Reset()
2.3 原理
- timer内部有3个变量,一个function,一个duration,一个C(即channel)。
- 当duration已expired,且已经从C中收过数据后,「只能」直接调Reset()
- 当duration已expired, 还未从C中收过数据时,必须用Stop+Reset()组合(此时Stop会返回false)
- 当duration未expired, (当然肯定也还未从C中收过数据时),必须用Stop+Reset()组合(此时Stop会返回true)
三 time.Since 和 defer
time.Since 必须被包括在 defer func 的 {} 花括号内, 才能生效, go 官方库特意提到了这一点
// defers: report common mistakes in defer statements
//
// The defers analyzer reports a diagnostic when a defer statement would
// result in a non-deferred call to time.Since, as experience has shown
// that this is nearly always a mistake.
//
// For example:
//
// start := time.Now()
// ...
// defer recordLatency(time.Since(start)) // error: call to time.Since is not deferred
//
// The correct code is:
//
// defer func() { recordLatency(time.Since(start)) }()
package defers