TinyGo 的 machine.Sleep() 提供三种硬件休眠模式:IDLE(CPU停、外设全开,唤醒快但功耗1–5mA)、DEEPSLEEP(仅RTC和唤醒引脚供电,功耗10–100μA,需重初始化外设)、STANDBY(功耗最低)。Go 本身不直接控制硬件睡眠与唤醒,必须通过 TinyGo 或嵌入式 runtime 配合底层寄存器操作;纯标准 Go(golang.org/dl/go1.25)在 Linux/macOS/Windows 上无法让设备真正进入深度睡眠并由外部事件唤醒。用 TinyGo 实现空闲/深度睡眠:Sleep() 函数的三种模式怎么选标准 Go 的 time.Sleep 只是协程挂起,CPU 仍在运行;真正省电得靠 TinyGo 提供的 machine.Sleep(),它会触发 MCU 硬件级休眠:machine.IDLE:CPU 停,外设(UART、I2C、ADC)全开,适合等待传感器中断或串口数据——唤醒快(微秒级),但功耗仍约 1–5 mAmachine.DEEPSLEEP:关掉大部分时钟域,仅 RTC 和唤醒引脚供电,电流可压到 10–100 μA;但唤醒后需重初始化外设,不能保留 GPIO 状态machine.STANDBY:功耗最低(常见错误:在 DEEPSLEEP 模式下还依赖未保存的全局变量,结果唤醒后值全为零;正确做法是把关键状态写进 RTC 备份寄存器或 EEPROM。唤醒源配置:为什么写了 Sleep 却死活不醒TinyGo 的 machine.Sleep() 不自动注册唤醒源,必须手动使能——比如用按钮唤醒,得提前配置引脚为外部中断:立即学习“go语言免费学习笔记(深入)”; RedClaw 百度推出的手机端万能AI Agent助手

更多推荐