EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
0.1 箴言 技术人员设计程序的首要目的是用于技术人员沟通和交流,其次才是用于机器执行。程序的生命力在于用户使用,程序的成长在于后期的维护及根据用户需求更新和升级功能。 如果你的程序只能由你来维护,当你离开这个程序时,你的程序也和你一起离开了,这将给公司和后来接手的技术人员带来巨大的痛苦和损失。 因此,为了程序可读、易理解、好维护,你的程序需要遵守一定的规范,你的程序需要设计。 “程序必须为阅读它的人而编写,只是顺便用于机器执行。” —— Harold Abelson 和 Gerald Jay Sussman “编写程序应该以人为本,计算机第二。” —— Steve McConnell 0.1 简介 为提高产品代码质量,指导仪表嵌入式软件开发人员编写出简洁、可维护、可靠、可测试、高效、可移植的代码,编写了本规范。 本规范将分为完整版和精简版,完整版将包括更多的样例、规范的解释以及参考材料(what & why),而精简版将只包含规则部分(what)以便查阅。 在本规范的最后,列出了一些业界比较优秀的编程规范,作为延伸阅读参考材料。 本规范主要包含以下两个方面的内容: 一:为形成统一编程规范,从编码形式角度出发,本规范对标示符命名、格式与排版、注释等方面进行了详细阐述。 二:为编写出高质量嵌入式软件,从嵌入式软件安全及可靠性出发,本规范对由于C语言标准、C语言本身、C编译器及个人理解导致的潜在危险进行说明及规避。 0.3 适用范围 本规范适用于XXX股份有限公司仪表台秤产品部嵌入式软件的开发,也对其他嵌入式软件开发起一定的指导作用。 0.4 术语定义 0.4.1 规范术语 原则:编程时必须坚持的指导思想。 规则:编程时需要遵循的约定,分为强制和建议(强制是必须遵守的,建议是一般情况下需要遵守,但没有强制性)。 说明:对原则/规则进行必要的解释。 实例:对此原则/规则从正、反两个方面给出例子。 材料:扩展、延伸的阅读材料。 Unspecified:未详细说明的行为,这些是必须成功编译的语言结构,但关于结构的行为,编译器的编写者有某些自由。例如C语言中的“运算次序”问题。这样的问题有 22 个。 在某种方式上完全相信编译器的行为是不明智的。编译器的行为甚至不会在所有可能的结构中都是一致的。 Undefined:未定义行为,这些是本质的编程错误,但编译器的编写者不一定为此给出错误信息。相应的例子是无效参数传递给函数,或函数的参数与定义时的参数不匹配。从安全性角度这是特别重要的问题,因为它们代表了那些不一定能被编译器捕捉到的错误。 Implementation-defined:实现定义的行为,这有些类似于“unspecified ”问题,其主要区别在于编译器要提供一致的行为并记录成文档。换句话说,不同的编译器之间功能可能会有不同,使得代码不具有可移植性,但在任一编译器内,行为应当是良好定义的。 比如用在一个正整数和一个负整数上的整除运算“/ ”和求模运算符“% ”。存在76个这样的问题。 从安全性角度,假如编译器完全地记录了它的方法并坚持它的实现,那么它可能不是那样至关重要。尽可能的情况下要避免这些问题。 0.4.2 C语言相关术语 声明(declaration):指定了一个变量的标识符,用来描述变量的类型,是类型还是对象,函数等。声明,用于编译器(compiler)识别变量名所引用的实体。以下这些就是声明: extern int bar;
; N+ ~ v: m& o
. t9 I/ e' ^2 j% }; Zextern int g(int,int);5 N; P) t U7 R
6 [0 O4 _% F/ S) u3 c9 G: }double f(int,double); [ 对于函数声明,extern关键字是可以省略的 。 定义(definition):是对声明的实现或者实例化。连接器(linker)需要它(定义)来引用内存实体。 与上面的声明相应的定义如下: int bar;
1 i; k9 l! H+ E" u$ S1 T, G \$ b' N0 W9 b% ^
int g(int lhs,int rhs)
9 @, j3 B' N7 n! M
7 n% V/ W: }, |0 ~1 |" A7 z{% }7 Y6 B8 c; v; L! V' h
" }* b% ?" T. a0 `& G+ Q return lhs*rhs;
+ l4 ~5 M, l/ Y1 c6 h/ u. b# P
. v! j' S/ l- _3 |) m4 g}
5 L1 g3 ?5 ~8 T/ ^5 h
" \/ [" T& q% L1 \; V. d! i8 j. Q, Gdouble f(int i,double d) {
" [+ J8 b. ?6 s8 S; y6 \% L4 A+ O ?6 l8 N) E
returni+d;
& \& Z$ G& _9 r) P
) ^! _4 f4 J# U) ?) N5 a} 0.5 规则的形式 规则/原则<序号>(规则类型):规则内容。 [原始参考] <序号>:每条规则都有一个序号,序号是按照章节目录-**的形式,从数字1开始。例如,若在此章节有个规则的话,序号为0.5-1。 (规则类型):或者是‘强制’,或者是‘建议’。 规则内容:此条规则的具体内容。 [原始参考]:指示了产生本条款或本组条款的可应用的主要来源。 [/hide]
, f8 _- C: t$ R) l/ O |