【golang】11、time、timer 和 ticker

一、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
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

呆呆的猫

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值