1. GPIO输入基础与硬件原理
在嵌入式系统开发中,按键作为最基础的人机交互接口,其可靠检测是每个工程师必须掌握的核心能力。不同于GPIO输出只需配置推挽/开漏结构并写入电平,GPIO输入涉及信号完整性、电气特性匹配、噪声抑制及状态机设计等多个工程维度。本节将从学习板实际电路出发,系统剖析STM32 GPIO输入的底层机制与实现逻辑。
1.1 学习板按键电路拓扑分析
根据学习板原理图第4页左下角所示,K1与K2两颗机械按键采用典型上拉结构设计。其中K1引脚PB12直接连接至外部10kΩ上拉电阻(R1),另一端接3.3V电源;K2引脚PB13则未配置外部上拉电阻,完全依赖STM32芯片内部上拉资源。两个按键的另一端均接地(GND),形成“按键按下→低电平,按键释放→高电平”的标准逻辑关系。
该设计的关键在于理解浮空输入(Floating Input)模式的本质:当GPIO配置为浮空输入时,其输入级处于高阻态(典型输入阻抗 > 10MΩ),此时引脚电平完全由外部电路决定。若无外部上拉/下拉元件,引脚将呈现不确定电平,极易受电磁干扰影响,导致误触发。因此,K1通过外部10kΩ电阻实现确定性上拉,而K2则启用内部上拉以简化PCB布线。
1.2 机械按键抖动的本质与危害
机械按键在触点闭合或断开瞬间,由于簧片弹性形变与接触面微小跳动,会在几毫秒(通常2–20ms)内产生多次通断振荡。这一现象称为按键抖动(Key Bounce)。对人类而言,该时间远低于感知阈值;但对运行于72MHz主频的STM32F103而言,一个10ms抖动周期内CPU可执行约72万条指令——这意味