使用 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产品图添加背景
相关推荐
Rsun045512 小时前
14、Java 模板方法模式从入门到实战2501_914245932 小时前
如何用 setCustomValidity 自定义表单验证失败的提示文本2301_817672262 小时前
bootstrap如何修改标签页切换的过渡时间2301_771717212 小时前
AQS极简版覆东流2 小时前
第3天:Python print深入与格式化输出蓝色的杯子2 小时前
JWT 到底怎么用?一篇讲透 + FastAPI 鉴权实战zhangchaoxies2 小时前
JavaScript中Tree-shaking失效的场景及其优化对策山峰哥2 小时前
SQL性能飞跃:从索引策略到查询优化的全链路实战指南2501_914245932 小时前
SQL在GROUP BY中如何保留非聚合列_配合ANY_VALUE或窗口函数