使用 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产品图添加背景
相关推荐
小糖学代码15 小时前
LLM系列:环境搭建:5.Python-dotenv 环境变量管理丷丩15 小时前
Postgresql基础实践教程(十一)各种Join星夜夏空9915 小时前
FreeRTOS学习(4)——内存映射智慧物业老杨15 小时前
智慧物业合同周期管理系统:从风险预警到智能交接的全流程数智化落地方案橙橙笔记16 小时前
Python的学习第一部分TheRouter16 小时前
AI Agent 记忆体系建设实战:短期、长期与工作记忆的工程实现Omics Pro16 小时前
首个!外源天然产物综合性代谢图谱voidmort16 小时前
3. 微调(Fine-tuning)与强化学习(RL)的核心思想biter down17 小时前
基于 Pywinauto 的 QQ 音乐 GUI 自动化测试实践人道领域17 小时前
【LeetCode刷题日记】669.修剪二叉搜索树