使用 time.AfterFunc 或手动延迟首次触发:先创建 ticker,再用 time.AfterFunc 延迟首次操作,或用 time.Timer 替代,避免 NewTicker 启动即触发。time.Ticker 一启动就触发,怎么避免第一次立即执行?默认情况下,time.NewTicker 创建后,第一次 就会立刻收到一个时间点------这不是 bug,是设计如此。如果你希望"等 1 秒后再执行第一次",不能靠 sleep 或手动丢弃,得换思路。用 time.AfterFunc + 循环重置:适合只执行一次初始延迟的场景改用 time.NewTimer 配合 for-select 手动重启:控制力最强,也最贴近"首次延后、后续周期"的真实需求别在 ticker 启动后加 time.Sleep 再读通道------竞态风险高,且无法保证精度示例(推荐):timer := time.NewTimer(1 * time.Second)defer timer.Stop()for { <-timer.C doWork() // 下次触发前再等 1 秒 timer.Reset(1 * time.Second)}为什么 ticker.Stop() 后还收到 tick?time.Ticker.Stop() 只阻止后续发送,不消费已排队的值。如果刚调用 Stop() 就立刻从 ticker.C 读,可能拿到"过期 tick"。必须配合通道接收 + select 超时或 default 分支做防御更稳妥的做法:停掉 ticker 后,用 for len(ticker.C) > 0 { 清空残留(仅限无其他 <a style="color:#f60; text-decoration:underline;" title="go" href="https://www.php.cn/zt/15863.html" target="_blank">go</a>routine 写入时)常见错误现象:panic: send on closed channel ------ 是因为 ticker 停了但还有 goroutine 在往它发在 HTTP handler 里启 ticker 会泄漏 goroutine 吗?会。HTTP handler 是短生命周期的,但 time.Ticker 启动后会持续向其通道发值,直到显式 Stop()。没停的 ticker 会让 goroutine 永驻内存。 Mokker AI AI产品图添加背景
相关推荐
2301_7815714219 小时前
JavaScript中Object-getOwnPropertySymbols获取方法倒霉熊dd20 小时前
Python学习(第一部分 语法与数据结构/核心基础)jump_jump20 小时前
Drizzle 凭什么贴着 Go 跑——从设计哲学到热路径源码jay神20 小时前
基于SpringBoot的宠物生命周期信息管理系统仅此,20 小时前
deep agent整合 DeepSeek 记录苍煜20 小时前
生产环境 JVM 参数实战计算指南秋920 小时前
MySQL 8.0.46 与 MySQL 9.7.0在sql语句方面的区别并举例说明一只数据集20 小时前
NVIDIA Nemotron AIQ Agentic Safety Dataset:面向企业级智能体系统的安全与防护评估数据集全面解析ftpeak20 小时前
AI开发之LangGraph教程6~自定义状态 (Custom State)Amazinqc21 小时前
Mysql数据库数据软隔离的并发死锁情况