1.排版
1-1:程序块要采用缩进风格编写,缩进为4个空格,一般编辑器都可以设置,敲Tab键会自动插入4个空格。VC6中在Tools-Options-Tabs下设置。
1-2:相对独立的程序块之间、变量声明之后必须加空行。
1-3:较长的语句(>90字符)要分成多行书写,长表达式要在低优先级操作符处划分新行,操作符放在新行之首,划分出的新行要进行适当的缩进,使排版整齐,语句可读。
1-4:循环、判断等语句中若有较长的表达式或语句,则要进行适应的换行,长表达式要在低优先级操作符处划分新行,操作符放在新行之首。
1-5:若函数或过程中的参数较长,则要进行适当的换行。
1-6:不允许把多个短语句写在一行中,即一行只写一条语句。
1-7:if、while、for、default、do等语句自占一行。
1-8:代码中不包含TAB键,使用4个空格键代替。
1-9:函数或过程的开始、结构的定义及循环、判断等语句中的代码都要采用缩进风格,case语句下的情况处理语句也要遵从语句缩进要求。
1- 10:程序块的分界符"{"要在同一行,"}"应各独占一行,同时与引用它们的语句左对齐。在函数体的开始、类的定义、 结构的定义、枚举的定义以及if、for、do、while0、switch、case语句中的程序都要采用如上的缩进方式。
1-11:在两个以上的关键字、变量、常量进行对等操作时,它们之间的操作符之前、之后或者前后要加空格;进行非对等操作时,如果是关系密切的立即操作符(如->),后不应加空格。
1-12: 程序结构清析,简单易懂,单个函数的程序行数不得超过100行。
2.注释
2-1:尽量通过变量和方法命名让代码可读,只在很难看懂代码含义的地方加注释,不要过度注释。
-2-2:说明性文件(如头文件.h文件、.inc文件、.def文件、编译说明文件.cfg等)头部应进行注释,注释必须列出:版权说明、版本号、生成日期、作者、内容、功能、与其它文件的关系、修改日志等,头文件的注释中还应有函数功能简要说明。
-
2-3:源文件头部应进行注释,列出:版权说明、版本号、生成日期、作者、模块目的/功能、主要函数及其功能、修改日志等。 。VC中配置方法
2-4:函数头部应进行注释,列出:函数的目的/功能、输入参数、输出参数、返回值、调用关系(函数、表)等。。VC中配置方法
2-5:修改代码同时修改相应的注释,以保证注释与代码的一致性。不再有用的注释要删除。
2-6:注释的内容要清楚、明了,含义准确,防止注释二义性。
2-7:避免在注释中使用缩写,特别是非常用缩写。
2-8:注释应与其描述的代码相近,对代码的注释应放在其上方或右方(对单条语句的注释)相邻位置,不可放在下面,如放于上方则需与其上面的代码用空行隔开。
2-9:应该尽量在变量常量命名中体现其含义,对于所有有物理含义变量、常量,如果其命名不是充分自注释的,在声明时都必须加以注释,说明其物理含义。变量、常量、宏的注释应放在其上方相邻位置或右方。
2-10:数据结构声明(包括数组、结构、类、枚举等),如果其命名不是充分自注释的,必须加以注释。对数据结构的注释应放在其上方相邻位置,不可放在下面;对结构中的每个域的注释放在此域的右方。
2-11:全局变量要有较详细的注释,包括对其功能、取值范围、哪些函数或过程存取它以及存取时注意事项等的说明。
2-12:注释与所描述内容进行同样的缩排。
2-13:将注释与其上面的代码用空行隔开。
2-14:对含义不明显的分支语句(条件分支、循环语句等)编写注释。
2-15:对于switch语句下的case语句,如果因为特殊情况需要处理完一个case后进入下一个case处理,必须在该case语句处理完、下一个case语句前加上明确的注释。
3.标识符命名
3-1:标识符的命名要清晰、明了,有明确含义,同时使用完整的单词或大家基本可以理解的缩写,避免使人产生误解。
3-2:命名中若使用特殊约定或缩写,则要有注释说明。
3-3:命名风格统一,请遵守下面规范:
- )文件名以大写字母开头,如果文件名包含多个单词,每个单词首字母大写,例如 SimpleSearcher?
.c
-2)对于结构体的定义:TG_name,其中name自己定义,首字母大写,如果是指针定义为:TG_pname,其中name
自己定义,首字母大写
-
- )在头文件前的声明时,统一为:如对于head.h,定义为:_HEAD_H,,即.#ifndef
_HEAD_H
3-4:对于变量命名,禁止取单个字符(如i、j、k...),建议除了要有具体含义外,还能表明其变量类型、数据类型等,但i、j、k作局部循环变量是允许的。
3-5: 变量名称和函数名称全部小写,多个单词以下划线分开,例如 search_poi, tile_buffer。
4.可读性
4-1:注意运算符的优先级,并用括号明确表达式的操作顺序,避免使用默认优先级。
4-2:避免使用不易理解的数字,用有意义的标识来替代。涉及物理状态或者含有物理意义的常量,不应直接使用数字,必须用有意义的枚举或宏来代替。
5.变量
5-1:去掉没必要的公共变量。
5-2:仔细定义并明确公共变量的含义、作用、取值范围及公共变量间的关系。
5-3:明确公共变量与操作此公共变量的函数或过程的关系,如访问、修改及创建等。
5-4:当向公共变量传递数据时,要十分小心,防止赋与不合理的值或越界等现象发生。
5-5:防止局部变量与公共变量同名。
5-6:不要使用未经初始化的变量作为右值。
6.函数、过程
6-1:对所调用函数的错误返回码要仔细、全面地处理。
-6-2:明确函数功能,精确(而不是近似)地实现函数设计。
-
6-3:编写可重入函数时,应注意局部变量的使用(如编写C/C++语言的可重入函数时,应使用auto即缺省态局部变量或寄存器变量)。
6-4:编写可重入函数时,若使用全局变量,则应通过关中断、信号量(即P、V操作)等手段对其加以保护。
7.可测性(这部分需要更新)
7-1:在同一项目组或产品组内,要有一套统一的为集成测试与系统联调准备的调测开关及相应打印函数,并且要有详细的说明。
7-2:在同一项目组或产品组内,调测打印出的信息串的格式要有统一的形式。信息串中至少要有所在模块名(或源文件名)及行号。
7-3:编程的同时要为单元测试选择恰当的测试点,并仔细构造测试代码、测试用例,同时给出明确的注释说明。测试代码部分应作为(模块中的)一个子模块,以方便测试代码在模块中的安装与拆卸(通过调测开关)。
7-4:在进行集成测试/系统联调之前,要构造好测试环境、测试项目及测试用例,同时仔细分析并优化测试用例,以提高测试效率。
7-5:使用断言来发现软件问题,提高代码可测性。
7-6:用断言来检查程序正常运行时不应发生但在调测时有可能发生的非法情况。
7-7:不能用断言来检查最终产品肯定会出现且必须处理的错误情况。
7-8:对较复杂的断言加上明确的注释。
7-9:用断言确认函数的参数。
7-10:用断言保证没有定义的特性或功能不被使用。
7-11:用断言对程序开发环境(OS/Compiler/Hardware)的假设进行检查。
7-12:正式软件产品中应把断言及其它调测代码去掉(即把有关的调测开关关掉)。
7-13:在软件系统中设置与取消有关测试手段,不能对软件实现的功能等产生影响。
7-14:用调测开关来切换软件的DEBUG版和正式版,而不要同时存在正式版本和DEBUG版本的不同源文件,以减少维护的难度。
7-15:软件的DEBUG版本和发行版本应该统一维护,不允许分家,并且要时刻注意保证两个版本在实现功能上的一致性。
8.质量保证
8-1:过程/函数中分配的内存,在过程/函数退出之前要释放。
8-2:过程/函数中申请的(为打开文件而使用的)文件句柄,在过程/函数退出之前要关闭。
8-3:系统运行之初,要初始化有关变量及运行环境,防止未经初始化的变量被引用。
8-4:系统运行之初,要对加载到系统中的数据进行一致性检查。
8-5:有可能的话,if语句尽量加上else分支,对没有else分支的语句要小心对待;
8-6: switch语句必须有default分支。
8-7: 禁止GOTO语句。
8-8:单元测试是编程的一部份,提交联调测试的程序必须通过单元测试。
9.宏
12-1:用宏定义表达式时,要使用完备的括号。
12-2: 将宏所定义的多条表达式放在大括号中。
12-3: 使用宏时,不允许参数发生变化
分享到:
相关推荐
C语言编码规范 C语言编码规范是编写高质量C语言代码的重要指南。遵守这些规则可以确保代码的可读性、可维护性和可靠性。本文将详细介绍C语言编码规范的各个方面,包括文件组织、命名约定、编程风格、注释、错误处理...
C语言编码规范是软件开发中的重要组成部分,尤其在大型企业如华为等,为了确保代码的质量、可读性和可维护性,都有严格的编码标准。本文将深入探讨C语言的编码规范,以及与C++相关的规范,帮助开发者理解并遵循这些...
标题中提到的《安富莱C语言编码规范》实际上是一份关于如何规范编写C语言代码的指南。文档涵盖了文件命名、目录结构、头文件引用等多个方面,旨在提升代码的可读性、可维护性和移植性。 文件命名需要准确清晰地表达...
本文档《C语言编码规范-强烈推荐.doc》提供了一系列实用的编码规范,以帮助开发者编写出更清晰、规范且易于维护的C语言代码。 首先,编码风格的规范是整个编码规范的基础。良好的编码风格不仅让代码看上去整洁美观...
C语言编码规范概述 C语言自1972年由Dennis Ritchie发明以来,由于其强大的功能以及灵活性,被广泛应用于软件开发的各个领域。为了提高代码的可读性和可维护性,编码规范的重要性不言而喻。本文档将集中讨论C语言开发...
### C语言编码规范知识点 #### 一、引言 C语言是一种广泛使用的高级编程语言,因其高效、灵活而深受开发者喜爱。为了确保C语言代码的质量、可读性和可维护性,制定一套统一的编码规范至关重要。本文档将详细介绍...
以下是对"C语言编码规范学习"这一主题的详细阐述: 1. **命名规则**: - 变量名和函数名应具有描述性,避免使用单字母或者无意义的缩写。 - 使用小写字母,多个单词组成时用下划线连接,如`my_variable_name`或`...
### 经典C语言编码规范提高编码效率必备 #### 一、引言 在软件开发过程中,编码规范扮演着至关重要的角色。一个良好的编码规范不仅可以提高代码的可读性和可维护性,还能促进团队协作,减少错误的发生。本文将详细...
C语言编码规范是提高编程质量的关键,良好的编码规范能够使代码更易读、易维护,反映出程序员的专业素养。以下是对规范的详细说明: **排版规范:** 1. 使用缩进风格,通常一个TAB键代表一个缩进层级,使得代码层次...
### C语言编码规范详解 #### 一、程序排版 **规则:** 1. 较长的语句(超过80个字符)应当分成多行书写。为了保持代码的清晰性和可读性,建议在低优先级操作符处进行换行,并确保新行的开头放置该操作符。 2. 循环...
很有用的C语言编码学习,让你成为一个专业的C语言开发者,对于新手起到良好的指导作用,对于精通C语言的程序员不防是一本很好的编码参考手册.包括C语言编码规则,C语言编码风格,排版,命名方式等.
某公司C语言编码规范 一、标识符 标识符的命名要清晰、明了,有明确含义。使用完整的单词或大家基本可以理解的缩写,避免使人产生误解。 标识符应当采用英文单词或其组合,切忌使用汉语拼音来命名... 二、排版 名字...
编码的规范 实际项目中编码需要规范 具体项目中的规范要求
华为c++编码规范和安全编码规范最新3.1版本 华为c++编码规范和安全编码规范最新3.1版本 华为c++编码规范和安全编码规范最新3.1版本 华为c++编码规范和安全编码规范最新3.1版本 华为c++编码规范和安全编码规范最新3.1...
C语言编码规范 C语言编码规范是指在编写C语言代码时需要遵守的一系列规则和约定,以确保代码的可读性、可维护性和可扩展性。本规范涵盖了代码结构、命名约定、注释风格、变量、宏、常量、函数等多个方面。 代码...