基于单片机C语言编程格式 点击:173 | 回复:0



研讨会宣传员_3259

    
  • [版主]
  • 精华:3帖
  • 求助:110帖
  • 帖子:1927帖 | 14403回
  • 年度积分:102
  • 历史总积分:64749
  • 注册:2020年3月27日
发表于:2016-10-12 21:36:07
楼主

1. 凡是注解均用如下长度的字符数,此数是正常情况下在keil中A4纸的打印长度(105个字符),在word中设置左右边距为1.0cm。

/******************************************************************************************************/

2. 文件头的格式:

/*******************************************************************************************************   
*                                         Company Name                                                
*                                           Address
*  
*                         (c) Copyright 20xx, Company Name, City, State
*                                    All Rights Reserved
*
*
* FileName       :
* Version        :
* Programmer(s)  :
* Description    :
*
*
*******************************************************************************************************/

3. 函数头的格式:

/*******************************************************************************************************
* FunctionName   :
* Description    :
* EntryParameter :
* ReturnValue    :
*******************************************************************************************************/

4. 文件结束格式:

/*******************************************************************************************************
*                                         End Of File                                                 
*******************************************************************************************************/

5. 文件管理:
 
   对于文件的管理来说,应把每一个程序模块分成两份。一个是C语言源代码,一个对应的头文件,且放在一个文件夹中。
例如,关于LCD1602的驱动模块,应该分为LCD1602.C和LCD1602.H,并放在LCD1602文件夹中。LCD1602.C中包含的是驱动程序
的源代码,尽量做到与移植无关;LCD1602.H中应该包含函数的申明部分、宏定义、全局变量的申明接管脚定义等,也就是
与移植相关的部分。
   对于main.c函数应该对于config.h头文件。main.c中为应用程序的主程序部分,负责把各个模块联系起来;而config.h头
文件为整个系统的配置文件,里边除了编写不依赖于编译器的数据类型的定义外,还应该把整个工程需要的所有程序模块均包含进来,这样每一个程序
模块中都只需要包含config.h头文件即可。

6. 命名规则:

   A. 函数命名:
      函数名均由大写字母开头,单词之间也应用大写区别,为了移植以后程序模块的函数名不重复,应在程序模块的每一个函数名中加上模块名。如: LCDWriteData(),LCD表示液晶模块,WriteData写数据到液晶模块中。至于下划线的带与否,可以用与区分是函数的内部函数与否,也就是说,如果带下划线,表示为模块内部函数,应用程序可能不需要调用,模块内部调用;不带下划线表示为应用程序需要调用的函数。
   B. 变量命名:
      全局变量 -- 大写字母开头,并且加上文件名为变量前缀。
      局部变量 -- 小写字母开头,
      内部变量 -- 用简单字母表示,如:循环用i,j,k等;指针 - p,字符 - c,字符串 - s。
   
   总结:形式参数 -- 在函数中应也小写开头;
         自动变量 -- 小写字母;
         静态变量 -- 大写开头;
         外部变量 -- 文件名开头;
         函数命名 -- 文件名开头。

7. 注解规则:

   对于函数的注解均该应“//”来表示,而不是“/**/”。因为前者表示后,如果想把整段代码注释掉只要加上后者,但如果一开始就用了后者,再想注释掉整段代码就比较麻烦了。注解应该对齐,如果一行写不下,可以写在代码的前面一行,也可以在后面一行继续编写。

8. 代码编写格式:
 
   对于代码的编写格式,将严格按照《c语言编程规范》来编写。
 
9. 宏的定义:
   
   常数和宏定义要用全大写表示,单词之间可以用下划线分割开。十六进制要用“0x”开头,其后的字母一定要用大写表示。如果是定义的是常量不需要加括号,但是表示的是一个或更多的语句时应该加上括号,而要替代的表达式均应加括号。如:

   #define  KEY_FF            (0x0F)                   // 常量定义,常量后不加括号,表达式加括号
   #define  KEY_BUF_FULL()    (KeyNRd > 0)             // 语句应加括号

10. 数据类型:

    typedef     unsigned    char      Boolean;         // Boolean                                           位变量
    typedef     unsigned    char      uint8;           // defined for unsigned 8-bits integer variable      无符号8位整型变量 
    typedef     signed      char      int8;            // defined for signed 8-bits integer variable     有符号8位整型变量
    typedef     unsigned    short     uint16;          // defined for unsigned 16-bits integer variable     无符号16位整型变量
    typedef     signed      short     int16;           // defined for signed 16-bits integer variable       有符号16位整型变量
    typedef     unsigned    int       uint32;          // defined for unsigned 32-bits integer variable     无符号32位整型变量
    typedef     signed      int       int32;           // defined for signed 32-bits integer variable       有符号32位整型变量
    typedef     float                 fp32;            // single precision floating point variable (32bits) 单精度浮点数(32位长度)
    typedef     double                fp64;            // double precision floating point variable (64bits) 双精度浮点数(64位长度)

11. 局部变量:
  
   一些程序模块会用到局部变量,这些局部变量只用于这个模块中,应将这些局部变量隐藏起来,不让别的文件看到。则应该在这写变量前加上static关键字实现。

12. 括号应用:
 
   在多个运算符存在的条件下,应该应用括号,避免优先级的错误及阅读方便。如:

       ssY = ssM * ssX + ssB;   应写成 : ssY = ((ssM * ssX) + ssB);

13. 真假定义:

   当定义逻辑对立面时,基于原始的陈述,以宏的方式,首先定义其中一种逻辑情形,然后再定义相反的另一种情形。

       #define TRUE    (1)
       #define FALSE   (!TRUE)




楼主最近还看过


热门招聘
相关主题

官方公众号

智造工程师