当前位置: 首页 > news >正文

【08】单片机变量命名规范指南

【08】单片机变量命名规范指南

(基于单片机开发实践,适用于 C/C++ 语言)

📌 核心原则

1️⃣ 清晰性:通过前缀、后缀、大小写区分变量类型、作用域、数据宽度等。
2️⃣ 一致性:同一项目内规则统一,避免混用不同命名风格。
3️⃣ 可读性:命名需反映变量用途,避免单字母(除循环变量)。


📝 1. 普通变量命名规范

🔹 类型前缀
前缀含义示例
uint8_t无符号8位局部变量uint8_tData
uint16_t无符号16位局部变量uint16_tCount
uint32_t无符号32位局部变量uint32_tTime
🔹 作用域标识
前缀含义示例
无前缀局部变量(默认)uint8_tTemp
G全局变量Guint8_tStatus
ES全局静态变量ESuint16_tCounter
S局部静态变量Suint32_tTimer

📝 2. 常量命名规范

🔹 常量前缀
前缀含义示例
C所有常量(全局/局部)Cuint8_tMaxValue = 255
C结合类型前缀(如 Cuint8_t, Cuint16_tconst unsigned int Cuint16_tLimit = 65535;

📝 3. 循环变量命名规范

  • 例外规则:循环变量允许使用单字母命名(如 i, j, k),无需遵循其他命名规范。
  • 示例
    for (unsigned char i = 0; i < 10; i++) {  
        // 循环体  
    }  
    

📝 4. 数组命名规范

🔹 用途后缀
后缀用途示例
Buffer普通数据缓冲区Guint8_tDataBuffer[10]
String字符串数组Guint8_tMessageString[50]
Table查找表/映射表const Cuint8_tLookupTable[] = {0x3F, ...};
Message存储结构化信息的数组uint8_tConfigMessage[16]

📝 5. 指针命名规范

🔹 指针前缀
前缀含义示例
p指针变量unsigned char *pGuint8_tData;
pC常量指针(指向常量)const unsigned int *pCuint16_tValue;
🔹 作用域与类型
前缀组合含义示例
pGuint8_t全局8位变量指针unsigned char *pGuint8_tArray;
pSuint16_t局部静态16位变量指针static uint16_t *pSuint16_tPtr;

📝 6. 结构体命名规范

🔹 结构体前缀
前缀含义示例
t结构体变量/指针struct StructData tConfig;
Gt全局结构体变量GtSensorData;
St局部静态结构体变量static struct Data StTemp;
pt结构体指针struct Struct *ptData;

📝 7. 宏常量命名规范

  • 全大写字母,单词间用下划线分隔。
  • 示例
    #define MAX_RETRIES 3  
    #define EEPROM_ADDR 0x50  
    

📝 8. 通用命名规则

🔹 单词分隔
  • 驼峰式命名:多个单词首字母大写,如 uint8_tGetFileLength
  • 下划线分隔:专业术语或难以断句的单词间用 _,如 Guint8_tESD_Flag
🔹 禁用规则
  • 避免单字母命名(除循环变量)。
  • 避免缩写(如 cntcount)。

🌟 总结

本规范通过 前缀+后缀+大小写 的组合,实现以下目标:
1️⃣ 类型可见uint8_t/uint16_t/uint32_t 明确数据宽度。
2️⃣ 作用域清晰G/ES/S 区分全局、静态变量。
3️⃣ 用途明确Buffer/Table/String 标识数组用途。
4️⃣ 可读性优先:宏常量全大写,结构体前缀统一。

实践建议

  • 新项目初期严格遵循规范,后期根据需求微调。
  • 单片机开发中需特别注意 b/h/l 类型修饰符(如 Keil C51)。
  • 代码注释需与命名规范互补,避免过度依赖注释。

💡 终极目标:让代码成为“自文档”,无需额外说明即可理解变量用途与约束。

相关文章:

  • AI编程工具-(七)
  • 【鸿蒙开发】入门篇:node与express
  • 优化 NFS 挂载参数以提升可靠性与容错性
  • Spring Boot 日志
  • LabVIEW基于双通道FFT共轭相乘的噪声抑制
  • 关于统计建模大赛的选题
  • 【鸿蒙开发】Hi3861学习笔记- 软件定时器示例
  • 【Linux】进程间通信
  • 批量创建BOM的RFC接口
  • 常见的设计模式和应用场景(一)
  • 文本转语音-音画适时推送rtsp并播放
  • 静态路由实验
  • Spring Boot/Spring Cloud 整合 ELK(Elasticsearch、Logstash、Kibana)详细避坑指南
  • 【CSS3】元婴篇
  • [数据结构]并查集
  • 【 <一> 炼丹初探:JavaWeb 的起源与基础】之 JavaWeb 项目的部署:从开发环境到生产环境
  • 智能焊机监测系统:打造工业安全的数字化盾牌
  • Git合并工具在开发中的使用指南
  • 常用中文开源embedding模型应用
  • printk相关说明
  • 罗马尼亚总理乔拉库宣布辞职
  • 新闻1+1丨多地政府食堂开放 “舌尖上的服务”,反映出怎样的理念转变?
  • 建邦高科赴港上市,大股东陈子淳系山东建邦集团董事长陈箭之子
  • 演员扎堆音乐节,是丰富了舞台还是流量自嗨?
  • 中央气象台:未来三天北方地区有大风沙尘,江南等地有强降水
  • 上海环球马术冠军赛开赛,一场体育与假日消费联动的狂欢