STM32-标准库-GPIO-API函数
1.void GPIO_DeInit(GPIO_TypeDef* GPIOx);
@简明 | 清除GPIOx的外围寄存器下所有引脚的配置, 恢复到默认配置状态(即上电初始值) |
@参数 | GPIOx:其中x可以是(A..G)来选择GPIO外设。 |
@返回值 | None |
void GPIO_DeInit(GPIO_TypeDef* GPIOx);
(1)通常用于以下场景:
动态切换外设功能前清除残留配置。 |
系统低功耗模式下减少 GPIO 漏电流。 |
错误恢复时强制重置 GPIO 状态。 |
(2)注意事项
复位操作依赖时钟 | 1.必须确保 GPIO 时钟已使能:复位操作需通过 RCC 寄存器完成, 若 GPIO 时钟未开启(例如调用 RCC_APB2PeriphClockCmd(GPIOx_CLOCK, DISABLE)),否则GPIO_DeInit() 将无效 |
2.复位后不会自动关闭时钟,需手动禁用以降低功耗(若不再使用)。 |
2.void GPIO_AFIODeInit(void);
@简明 | 将复用功能(重映射、事件控制和EXTI配置)寄存器取消复用功能,恢复默认状态值。 |
@参数 | None |
@返回值 | None |
void GPIO_AFIODeInit(void);
(1)注意事项
复位范围 : 影响所有 AFIO 相关配置 | 复用功能重映射(如 USART、SPI 引脚重映射) | |
外部中断线(EXTI)与 GPIO 引脚的绑定关系 | ||
事件输出功能(GPIO_EventOutputConfig)的配置 | ||
调试端口(如 SWJ/JTAG)的引脚分配(可能影响调试器连接) | ||
外设依赖风险 | 复用功能失效: | 若 GPIO 用于外设重映射(如 USART1 重映射到 PB6/PB7),复位后需重新配置。 |
中断丢失 | 若 EXTI 中断依赖 AFIO 配置(如 GPIO_EXTILineConfig),复位后需重新绑定引脚并配置 NVIC | |
调试接口影响 | 默认状态下,调试端口(SWJ/JTAG)可能被禁用或重新分配,导致调试器断开连接 |
3.void GPIO_Init(GPIO_TypeDef* GPIOx,GPIO_InitTypeDef* GPIO_InitStruct);
@简明 | 用来初始化GPIO引脚的配置,比如设置模式、速度、上下拉等。 | |
@参数 | @参数1 | GPIOx:其中x可以是(A..G)来选择GPIO外设。 |
@参数2 | GPIO_InitStruct:指向GPIO_InitTypeDef结构的指针,该结构包含指定GPIO外围设备的配置信息。 | |
@返回值 | None |
void GPIO_Init(GPIO_TypeDef* GPIOx,GPIO_InitTypeDef* GPIO_InitStruct);
(1)参数2:GPIO_InitStruct
GPIO_InitStruct | GPIO_Pin | 引脚编号(位掩码,如 GPIO_Pin_0 | GPIO_Pin_1)。 | ||
GPIO_Mode | 引脚模式(输入/输出/复用/模拟) | 输入模式 | GPIO_Mode_AIN /* 模拟输入模式 / GPIO_Mode_IN_FLOATING / 浮空输入 / GPIO_Mode_IPD / 下拉输入模式 / GPIO_Mode_IPU / 上拉输入模式 */ | |
输出模式 | GPIO_Mode_Out_OD /* 开漏输出 / GPIO_Mode_Out_PP / 推挽输出 / GPIO_Mode_AF_OD / 复用开漏输出/ GPIO_Mode_AF_PP / 复用推挽输出 */ | |||
GPIO_Speed | 输出速度(低速/中速/高速) | GPIO_Speed_10MHz = 1, GPIO_Speed_2MHz, GPIO_Speed_50MHz | ||
GPIO_OType | 输出类型(推挽/开漏) | |||
GPIO_PuPd | 上下拉电阻配置(无/上拉/下拉) |
(2)适用场景
初始化 GPIO 引脚为输入(如按键检测) | |
配置引脚为输出(如控制 LED)。 | |
设置复用功能(如 USART、SPI 通信) | |
模拟模式(如 ADC/DAC 信号采集) |
4.void GPIO_StructInit(GPIO_InitTypeDef* GPIO_InitStruct)
@简明 | 该函数用于快速初始化 GPIO 配置结构体,避免手动赋值的冗余操作, 通常在自定义配置前调用,确保未显式设置的参数具有合理的默认值。 | |||
@参数 | GPIO_InitStruct | 成员 | 默认值 | 说明 |
GPIO_Pin | GPIO_Pin_None | 无引脚被选中。 | ||
GPIO_Mode | GPIO_Mode_IN | 浮空输入模式。 | ||
GPIO_Speed | GPIO_Speed_2MHz | 低速模式(2MHz)。 | ||
GPIO_OType | GPIO_OType_PP | 推挽输出(仅在输出模式下有效)。 | ||
GPIO_PuPd | GPIO_PuPd_NOPULL | 无上下拉电阻。 | ||
@返回值 | 无 |
void GPIO_StructInit(GPIO_InitTypeDef* GPIO_InitStruct)
(1)注意事项
-
必须显式覆盖默认值:调用
GPIO_StructInit
后,需手动设置目标参数(如GPIO_Pin
、GPIO_Mode
),否则配置无效。
GPIO_InitTypeDef GPIO_InitStruct; GPIO_StructInit(&GPIO_InitStruct); // 初始化默认值 GPIO_InitStruct.GPIO_Pin = GPIO_Pin_5; // 覆盖引脚GPIO_InitStruct.GPIO_Mode = GPIO_Mode_OUT; // 覆盖模式GPIO_Init(GPIOA, &GPIO_InitStruct);
-
默认模式的风险:
-默认的浮空输入模式(GPIO_Mode_IN
)可能导致引脚电平不稳定,需根据实际需求调整。
-默认低速模式(GPIO_Speed_2MHz
)可能不适用于高频信号(如 SPI 通信)
-
与
GPIO_Init
的配合:
-GPIO_StructInit
仅初始化结构体,不会配置硬件寄存器,需后续调用 GPIO_Init
生效。
-
多引脚配置优化:
-若需重复配置不同引脚,可复用同一结构体,避免重复初始化:
GPIO_InitTypeDef GPIO_InitStruct;
GPIO_StructInit(&GPIO_InitStruct); // 配置 PA5 为输出
GPIO_InitStruct.GPIO_Pin = GPIO_Pin_5;
GPIO_InitStruct.GPIO_Mode = GPIO_Mode_OUT;
GPIO_Init(GPIOA, &GPIO_InitStruct); // 配置 PA6 为输入
GPIO_InitStruct.GPIO_Pin = GPIO_Pin_6;
GPIO_InitStruct.GPIO_Mode = GPIO_Mode_IN;
GPIO_Init(GPIOA, &GPIO_InitStruct);
5.uint8_t GPIO_ReadInputDataBit(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin);
@简明 | 读取指定的输入端口引脚。 适用范围:适用于按键检测、传感器信号读取等场景。 | ||
@参数 | 参数1 | GPIOx | GPIO 端口 |
参数2 | GPIO_Pin | 引脚编号 | |
@返回值 | Bit_SET(1):引脚为高电平。 | ||
Bit_RESET(0):引脚为低电平。 |
uint8_t GPIO_ReadInputDataBit(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin);
6.uint16_t GPIO_ReadInputData(GPIO_TypeDef* GPIOx);
@简明 | 读取指定的GPIO输入数据端口。 | ||
@参数 | GPIOx | GPIOx:其中x可以是(A..G)来选择GPIO外设。 | |
@返回值 | 16位数据,每一位对应一个GPIO引脚的状态 { 0=低电平, 1=高电平 } |
uint16_t GPIO_ReadInputData(GPIO_TypeDef* GPIOx);
(1)注意事项
依赖条件 | 仅读取配置为输入模式(如 GPIO_Mode_IN)的引脚状态,输出模式引脚的值可能无效 | ||
输入模式有效性 | 仅在GPIO配置为输入模式(如浮空输入、上拉/下拉输入)时,返回值才有意义。 |
(2)位操作技巧
// 检查第n位是否为高电平
if (GPIO_ReadInputData(GPIOA) & (1 << n)) { /* 逻辑处理 */ }
7.uint8_t GPIO_ReadOutputDataBit(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin);
简明 | 读取指定GPIO端口的单个输出引脚的当前设置状态 及(高/低电平),返回0或1。 | ||
参数 | GPIOx | GPIOx:其中x可以是(A..G)来选择GPIO外设。 | |
GPIO_Pin | 指定要读取的端口位。 | ||
返回值 | uint8_t:0(低电平)或1(高电平)。 |
uint8_t GPIO_ReadOutputDataBit(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin);
(1)注意事项
依赖条件 | 仅对配置为输出模式(如推挽、开漏)的引脚有效, 输入模式引脚的结果无意义。 | |
典型应用场景 | 验证输出引脚的配置状态(如确认LED是否被设置为点亮、检查信号是否已发送)。 |
8.uint16_t GPIO_ReadOutputData(GPIO_TypeDef* GPIOx);
@简明 | 读取指定GPIO端口的所有输出引脚的当前设置状态(高/低电平),返回16位无符号整数。 | ||
@参数 | GPIOx: | GPIO端口(如GPIOA、GPIOB等)。 | |
@返回值 | uint16_t:16位数据,每一位对应一个GPIO引脚的输出状态(0=低电平,1=高电平)。 |
uint16_t GPIO_ReadOutputData(GPIO_TypeDef* GPIOx);
(1)注意事项
依赖条件 | 仅对配置为输出模式(如推挽、开漏)的引脚有效, 输入模式引脚的状态不会被反映。 | |
典型应用场景 | 批量读取输出引脚状态(如LED阵列控制、并行总线数据发送后验证状态)。 |
结束语
以上就是对STM32-标准库-GPIO-API函数的一个总结。
相关文章:
STM32-标准库-GPIO-API函数
1.void GPIO_DeInit(GPIO_TypeDef* GPIOx); 简明 清除GPIOx的外围寄存器下所有引脚的配置, 恢复到默认配置状态(即上电初始值) 参数 GPIOx:其中x可以是(A..G)来选择GPIO外设。 返回值 None void GPIO_DeInit(GPI…...

Java 文件操作 和 IO(4)-- Java文件内容操作(2)-- 字符流操作
Java 文件操作 和 IO(4)-- Java文件内容操作(2)-- 字符流操作 文章目录 Java 文件操作 和 IO(4)-- Java文件内容操作(2)-- 字符流操作观前提醒:1. Java中操作文件的简单介…...
机器学习与深度学习06-决策树02
目录 前文回顾5.决策树中的熵和信息增益6.什么是基尼不纯度7.决策树与回归问题8.随机森林是什么 前文回顾 上一篇文章地址:链接 5.决策树中的熵和信息增益 熵和信息增益是在决策树中用于特征选择的重要概念,它们帮助选择最佳特征进行划分。 熵&#…...
Netty 实战篇:构建简易注册中心,实现服务发现与调用路由
本文将为前面构建的轻量级 RPC 框架添加“服务注册与发现”功能,支持多服务节点动态上线、自动感知与调用路由,为构建真正可扩展的分布式系统打好基础。 一、背景:为什么需要注册中心? 如果每个客户端都硬编码连接某个 IP/端口的…...
微信小程序(uniapp)对接腾讯云IM
UniApp 对接腾讯云 IM(即时通讯)完整指南 一、项目背景与需求分析 随着社交场景的普及,即时通讯功能已成为移动应用的标配。腾讯云 IM(Tencent IM,即 TIM)提供稳定可靠的即时通讯服务,支持单聊…...

使用摄像头推流+VLC软件拉流
一、作用 使用摄像头创建rtsp链接,并使用VLC软件拉流显示。 二、步骤 1、安装FFmpeg库 下载地址:https://ffmpeg.org/download.htmlFFmpeg库的下载参考之前的博客,下载Win64版本即可:https://blog.csdn.net/beijixingcd/artic…...
python魔法函数
Python 中的魔法方法(Magic Methods),也称为特殊方法(Special Methods)或双下方法(Dunder Methods),是以双下划线 __ 开头和结尾的方法。它们用于定义类的行为,例如运算符…...

XCUITest 是什么
XCUITest(全称 Xcode UI Test)是苹果官方提供的 iOS/macOS UI 自动化测试框架,集成在 Xcode 开发工具中,专门用于测试 Swift/Objective-C 开发的应用程序。 1. XCUITest 的核心特点 ✅ 官方支持:苹果原生框架…...
使用k8s服务进行端口代理
创建registry-service.yaml 使用无Selector的Service Endpoints模式 vi registry-service.yaml编辑以下内容 apiVersion: v1 kind: Service metadata:name: registry-service spec:type: NodePortports:- name: httpprotocol: TCPport: 81 # Service内部端口targ…...

灌水论坛系统总体设计文档
一、实验题目 灌水论坛系统 二、实验目的 旨在通过一个相对完整且功能丰富的Web应用实例,全面地实践和巩固Web开发所需的各项核心技术和工程方法,从而提升其综合应用能力和解决实际开发问题的能力。它不仅仅是完成一个软件,更是一个学习、…...

Mac M1编译OpenCV获取libopencv_java490.dylib文件
Window OpenCV下载地址 https://opencv.org/releases/OpenCV源码下载 https://github.com/opencv/opencv/tree/4.9.0 https://github.com/opencv/opencv_contrib/tree/4.9.0OpenCV依赖 brew install libjpeg libpng libtiff cmake3 ant freetype构建open CV cmake -G Ninja…...

使用 Let‘s Encrypt 和 Certbot 为 Cloudflare 托管的域名申请 SSL 证书
一、准备工作 1. 确保域名解析在 Cloudflare 确保你的域名 jessi53.com 和 www.jessi53.com 的 DNS 记录已经正确配置在 Cloudflare 中,并且状态为 Active。 2. 安装 Certbot 在你的服务器上安装 Certbot 和 Cloudflare 插件。以下是基于 Debian/Ubuntu 和 Cent…...
【Python进阶】元编程、并发
目录 🌟 前言🏗️ 技术背景与价值🩹 当前技术痛点🛠️ 解决方案概述👥 目标读者说明🧠 一、技术原理剖析📊 核心架构图解💡 核心作用讲解🔧 关键技术模块说明⚖️ 技术选型对比🛠️ 二、实战演示⚙️ 环境配置要求💻 核心代码实现案例1:元类实现ORM框架…...
网络协议:[0-RTT 认证 ]
1. 为什么要 0-RTT 认证 降低延迟:SOCKS5 在无认证时需要 2 RTT(握手+请求),若加用户名/密码又要 3 RTT;0-RTT 通过合并步骤,目标是把握手+认证+请求都压缩到 1 RTT。 IE…...
单例模式的类和静态方法的类的区别和使用场景
单例模式的类和使用静态方法的类在功能上都能提供全局访问的能力,但它们在实现方式、特性和使用场景上存在差异,下面从多个方面进行比较: 1. 实现方式 单例模式的类 单例模式确保一个类只有一个实例,并提供一个全局访问点。通常…...
flowable中流程变量的概念(作用域)
核心概念:流程变量(Process Variables) 流程变量是 Flowable 工作流引擎中用于存储、传递和共享与业务流程相关的数据的机制。你可以将它们理解为附着在流程实例(或执行流、任务)上的键值对(Key-Value&…...
【基础算法】模拟算法
文章目录 算法简介1. 多项式输出解题思路代码实现 2. 蛇形方阵解题思路代码实现 3. 字符串的展开解题思路代码实现 算法简介 模拟,顾名思义,就是题目让你做什么你就做什么,考察的是将思路转化成代码的代码能力。 这类题一般较为简单…...
项目 react+taro 编写的微信 小程序,什么命令,可以减少console的显示
在 Taro 项目中,为了减少 console 的显示(例如 console.log、console.info 等),可以通过配置 terser-webpack-plugin 来移除生产环境中的 console 调用。 配置步骤: 修改 index.js 文件 在 mini.webpackChain 中添加 …...
Android 开发 Kotlin 全局大喇叭与广播机制
在 Android 开发中,广播机制就像一个神通广大的 “消息快递员”,承担着在不同组件间传递信息的重任。Kotlin 语言的简洁优雅更使其在广播机制的应用中大放异彩。今天,就让我们一同深入探索 Android 开发中 Kotlin 全局大喇叭与广播机制的奥秘…...

微信小程序关于截图、录屏拦截
1.安卓 安卓: 在需要禁止的页面添加 onShow() {if (wx.setVisualEffectOnCapture) {wx.setVisualEffectOnCapture({visualEffect: hidden,complete: function(res) {}})}},// 页面隐藏和销毁时需要释放防截屏录屏设置onHide() {if (wx.setVisualEffectOnCapture) {w…...

基于51单片机的音乐盒键盘演奏proteus仿真
地址: https://pan.baidu.com/s/1tZCAxQQ7cvyzBfztQpk0UA 提取码:1234 仿真图: 芯片/模块的特点: AT89C52/AT89C51简介: AT89C51 是一款常用的 8 位单片机,由 Atmel 公司(现已被 Microchip 收…...

【unity游戏开发——编辑器扩展】EditorUtility编辑器工具类实现如文件操作、进度条、弹窗等操作
注意:考虑到编辑器扩展的内容比较多,我将编辑器扩展的内容分开,并全部整合放在【unity游戏开发——编辑器扩展】专栏里,感兴趣的小伙伴可以前往逐一查看学习。 文章目录 前言一、确认弹窗1、确认弹窗1.1 主要API1.2 示例 2、三按钮…...
WPF中自定义消息弹窗
WPF 自定义消息弹窗开发笔记 一、XAML 布局设计 文件:MessageInfo.xaml <Window x:Class"AutoFeed.UserControls.MessageInfo"xmlns"http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x"http://schemas.microsoft.…...

Android之ListView
1:简单列表(ArrayAdapter) 1:运行的结果: 2:首先在MyListView里面创建一个按钮,点击的时候进行跳转。 这里让我吃惊的是,Button里面可以直接设置onClick .java里面的方法。 也即是点击这个按钮之后就会去…...
查服务器信息 常用的一些命令 =^^ =
本文主要记录Linux系统的各项指令工具 目录 一、系统基础信息 1. 操作系统与内核信息 2. 主机名与 IP 二、CPU 和内存使用 1. CPU 与内存占用情况(动态监控) 2. 只看 CPU 与内存用量 三、磁盘与文件系统 1. 磁盘空间使用情况 2. 磁盘 inode 使用…...
PS裁剪后像素未删除?5步解决“删除裁剪像素”失效问题
在Photoshop中遇到“删除裁剪的像素”功能失效的问题时,可能涉及软件设置、版本兼容性或操作流程错误。以下是具体原因和解决方案: 一、常见原因分析 未正确勾选“删除裁剪的像素”选项 在裁剪工具属性栏中,需手动勾选该选项才能永久删除裁剪…...

《Spring Cloud Gateway 快速入门:从路由到自定义 Filter 的完整教程》
1.网关介绍 在前面的学习中,我们通过Eureka和Nacos解决了辅助注册,使用Spring Cloud LoadBalance解决了负载均衡的问题,使用OpenFeign解决了远程调用的问题。 但是当前的所有微服务的接口都是直接对外暴露的,外部是可以直接访问…...

第3节 Node.js 创建第一个应用
Node.js 非常强大,只需动手写几行代码就可以构建出整个HTTP服务器。事实上,我们的Web应用以及对应的Web服务器基本上是一样的。 在我们创建Node.js第一个"Hello, World!"应用前,让我们先了解下Node.js应用是由哪几部分组成的&…...

我们来学mysql -- “数据备份还原”sh脚本
数据备份&还原 说明执行db_backup_cover.sh脚本 说明 环境准备:来源数据库(服务器A);目标数据库(服务器B)dbInfo.sh脚本记录基本信息 来源库、目标库的ip、port及执行路径 # MySQL 客户端和 mysqldump 的路径 MYSQL_CLIENT"/work/oracle/mysql…...
mkcert实现本地https
1.下载 mkcert 从 mkcert GitHub 发布页 下载适用于 Windows 的版本(如 mkcert-v1.4.4-windows-amd64.exe)。 安装 mkcert 以管理员身份运行命令提示符(CMD),执行以下命令安装并信任本地 CAÿ…...