分享

安富莱C语言编码规范 5

 袁先森lemon 2020-08-21
安富莱C语言编码规范 5--变量、结构、常量、宏


1、为了方便书写及记忆,变量类型采用如下重定义:
  1. typedef unsigned char uint8_t;

  2. typedef unsigned short uint16_t;

  3. typedef unsigned long int uint32_t;

  4. typedef signed char int8_t;

  5. typedef signed short int16_t;

  6. typedef signed long int int32_t;

  7. #define __IO volatile
复制代码

2、常见类型的前缀
(1)对于一些常见类型的变量,应在其名字前标注表示其类型的前缀。前缀用小写字母表示。前缀的使用请参照下列表格中说明。
(2)对于几种变量类型组合,前缀可以迭加。


3、变量作用域的前缀
为了清晰的标识变量的作用域,减少发生命名冲突,应该在变量类型前缀之前再加上表示变量作用域的前缀,并在变量类型前缀和变量作用域前缀之间用下划线‘-’隔开。
具体的规则如下:
(1)对于全局变量(global variable),在其名称前加“g”和变量类型符号前缀。
  1. uint32_t g_ulParaWord;

  2. uint8_t g_ucByte;
复制代码
(2)对于静态变量(static variable),在其名称前加“s”和变量类型符号前缀。
  1. static uint32_t s_ulParaWord;

  2. static uint8_t s_ucByte;
复制代码
(3)函数内部等局部变量前不加作用域前缀。
(4)对于常量,当可能发生作用域和名字冲突问题时,以上几条规则对于常量同样适用。注意,虽然常量名的核心部分全部大写,但此时常量的前缀仍然用小写字母,以保持前缀的一致性。


4、对于结构体命名类型,表示类型的名字,所有名字以小写字母“tag”开头,之后每个英文单词的第一个字母大写(包括第一个单词的第一个字母),其他字母小写,结尾_T 标识。单词之间不使用下划线分隔,结构体变量以 t 开头。
  1. /* 结构体命名类型名 */

  2. typedef struct tagBillQuery_T

  3. {

  4. ...

  5. }BillQuery_T;

  6. /* 结构体变量定义 */

  7. BillQuery_T tBillQuery;

  8. 对于枚举定义全部采用大写,结尾_E 标识。

  9. typedef enum

  10. {

  11. KB_F1 = 0, /* F1 键代码 */

  12. KB_F2, /* F2 键代码 */

  13. KB_F3 /* F3 键代码 */

  14. }KEY_CODE_E;
复制代码

5、常量、宏、模版的名字应该全部大写。如果这些名字由多个单词组成,则单词之间用下划线分隔。
宏指所有用宏形式定义的名字,包括常量类和函数类;常量也包括枚举中的常量成员。
  1. #define LOG_BUF_SIZE 8000
复制代码

6、不推荐使用位域。

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多