time.Ticker适用于严格周期任务,需手动Stop防止goroutine泄漏;time.AfterFunc用于延迟执行,两者均适合单机场景。

在 Go 中实现定时任务,最常用也最轻量的方式是 time.Ticker 和 time.AfterFunc。它们不依赖外部服务,适合单机场景下的周期性任务(如轮询、清理、心跳)或延迟执行(如延时重试、超时回调)。关键在于理解两者的适用边界和资源管理细节。
time.Ticker 适用于需要严格按固定间隔重复执行的任务,比如每 5 秒检查一次配置文件、每分钟上报一次指标。它内部使用一个后台 goroutine 持续发送时间信号到通道,因此必须手动调用 ticker.Stop() 防止 goroutine 泄漏。
interval 后,不是“立刻+interval”Ticker 不跳过,而是尽快连续触发(除非你手动跳过)select 配合 ctx.Done() 实现可取消的定时任务示例:每 3 秒打印一次,支持优雅停止
ticker := time.NewTicker(3 * time.Second)time.AfterFunc 是启动一个延迟后只执行一次的函数,底层基于 time.Timer,适合做延时重试、超时清理、异步回调等。它返回一个 *Timer,可通过 Stop() 取消未触发的任务,避免误执行。
立即学习“go语言免费学习笔记(深入)”;
AfterFunc 会创建多个 timer,记得保存并管理(尤其在循环或高频事件中)Stop() 再新建;如需周期性+可取消,优先选 Ticker
示例:3 秒后发送告警,但可在之前取消
timer := time.AfterFunc(3*time.Second, func() {两类定时器都容易因忽略生命周期导致内存泄漏或逻辑错误:
recover 包裹任务体对常用模式可做薄封装,比如带上下文取消和 panic 恢复的周期执行:
func RunEvery(ctx context.Context, d time.Duration, f func()) {调用:RunEvery(ctx, 10*time.Second, doBackup) —— 简洁、可控、健壮。
基本上就这些。Ticker 和 AfterFunc 足够覆盖大多数本地定时需求,不复杂但容易忽略 Stop 和错误处理。用好它们,比引入 cron 库或消息队列更轻量也更可控。
以上就是如何使用Golang定时执行任务_Golang time Ticker与AfterFunc技巧的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号