使用 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产品图添加背景
相关推荐
金銀銅鐵14 小时前
[Python] 从《千字文》中随机挑选汉字cup1119 小时前
[技术复盘] Windows Python 打包实战:Nuitka 环境踩坑总结与 CI 自动化构建全指南aqi0021 小时前
15天学会AI应用开发(七)有了大模型为什么还要引入RAG金銀銅鐵1 天前
用 Python 实现 Take-Away 游戏copyer_xyf1 天前
Agent 流程编排copyer_xyf1 天前
Agent RAGcopyer_xyf1 天前
【RAG】向量数据库:milvuscopyer_xyf1 天前
Agent 记忆管理星云穿梭2 天前
用Python写一个带图形界面的学生管理系统——完整教程