time.Timer用于延迟执行或超时控制,通过time.NewTimer创建,2秒后触发并写入当前时间到通道;2. 可调用Stop()方法提前取消定时器,适用于超时或取消操作场景。

在Go语言中,time.Timer 是一个用于在将来某一时刻执行一次任务的机制。它不像 time.Ticker 那样周期性触发,而是只触发一次。合理使用 Timer 可以实现延迟执行、超时控制等常见场景。
创建和使用Timer
通过 time.NewTimer 可以创建一个定时器,当到达设定时间后,Timer 会将其内部的通道(Channel)写入当前时间。
package mainimport ( "fmt" "time" )
func main() { // 创建一个2秒后触发的定时器 timer := time.NewTimer(2 * time.Second)
fmt.Println("开始等待...") // 阻塞,直到定时器触发 <-timer.C fmt.Println("定时器已触发")}
上面代码会在打印“开始等待...”两秒后输出“定时器已触发”。
立即学习“go语言免费学习笔记(深入)”;
停止Timer
如果想在定时器触发前取消它,可以调用 Stop() 方法。这在处理超时或用户提前取消操作时非常有用。
timer := time.NewTimer(5 * time.Second)
go func() {
time.Sleep(3 * time.Second)
timer.Stop() // 提前停止定时器
fmt.Println("定时器已被停止")
}()
<-timer.C // 注意:如果Stop成功,该接收操作可能永远不会返回
注意:调用 Stop() 后,不能保证通道是否已经被写入。若 Stop 返回 true,说明定时器未触发且已成功停止;若返回 false,表示定时器已触发或已被停止。
重置Timer
使用 Reset() 方法可以重新设置定时器的时间,使其再次开始倒计时。常用于需要重复延时处理的场景(如心跳检测)。
timer := time.NewTimer(1 * time.Second)
timer.Reset(3 * time.Second) // 修改为3秒后触发
<-timer.C
fmt.Println("重置后的定时器触发")
注意:在调用 Reset 前应确保原定时器已停止或已触发,否则可能引发竞态问题。Go 1.15+ 对 Reset 的并发安全性有所改进,但仍建议谨慎使用。
常见应用场景:超时控制
Timer 经常用于网络请求或IO操作的超时控制。
func doWithTimeout(timeout time.Duration) bool {
timer := time.NewTimer(timeout)
ch := make(chan bool)
go func() {
// 模拟耗时操作
time.Sleep(4 * time.Second)
ch <- true
}()
select {
case <-ch:
timer.Stop()
return true
case <-timer.C:
fmt.Println("操作超时")
return false
}}
func main() {
success := doWithTimeout(3 * time.Second)
fmt.Println("执行结果:", success)
}
上述例子中,如果操作在3秒内未完成,则认为超时,返回 false。
基本上就这些。Timer 简单高效,适合一次性延迟任务。掌握 Stop 和 Reset 的使用,能更好地控制程序行为,避免资源浪费或逻辑错误。










