20180925-5 代码规范,结对要求

此作业的要求:[https://edu.cnblogs.com/campus/nenu/2018fall/homework/2147]

结对伙伴:王玉潘

我们这次作业使用C语言编写,所以我们针对C语言的语法规则进行规范代码。

要求一

1.大小写

我们大体上采用单词首字母大写的方式命名,由多个单词组成的变量名,如果全部都是小写,很不易读,一个简单的解决方案就是用大小写区分它们。我们采用单词首字母大写的方式命名变量名,有两个具有实际意义的单词组成时,单词的首字母要大写,比如getstr,我们将这样书写GetStr。函数名我们也会将首个字母严格写成大写,比如Pop()。

2.注释

注释是为了解释程序是做什么(what),为什么这样做(why),以及要特别注意的地方。在定义数据结构时及实现某个功能的函数,在关键语句,难懂语句处注释,我们对这些代码进行解释,比如数据结构是定义的那种数据,函数实现了什么功能。在关键语句进行注释,让阅读程序的人能够理解这些代码的实际含义。没有这些注释,程序会变得晦涩难懂,自己过段时间也难以理解。

3.缩进

我们按照Code Blocks默认的缩进距离进行缩进,在必要的代码块进行缩进,没有缩进的代码太过杂乱,没有规范的缩进也会让人摸不到头脑。在while循环,for循环,if判断语句下,我们都用默认的缩进,我们的ide有智能的缩进功能。

4.分行

不要把多个变量定义在一行上,比如:我们不这么书写int num=1;ans=2;

我们要再起一行进行第二个变量的定义:

int num=1;

int ans=2;

if或else语句之后不再加实现功能的语句,比如:

if(判断条件)

{

     代码块;

}

else

{

      代码块;    

}

5.括号

在复杂的条件表达式中,用括号清楚地表示逻辑优先级。在复杂的循环程序中,我们也使用括号清楚地表所示逻辑关系。如果不加括号进行表示,会使得逻辑混乱,导致程序出错。比如if语句下只有一条代码时,不在其后面加括号,后续再这个判断语句后里加入代码时,就会产生错误,例如:

if(判断条件)

     a=b;

后续如果想要在if条件下加入别的语句,比如:

if(判断语句)

     a=b;

     c=b;

这时就会产生错误,c=b这条语句就没被加到里面。

6.函数

一个函数只执行一个功能,结构化编程时,让每一个函数实现一个功能会使编程变得比较容易。如果一个函数实现多个功能就不能达到结构化编程的效果,将每一个功能的实现都交付给一个函数,这样就能使编程变得明了,可读性也会变高。

7.行宽

行宽超出了100字符,行宽过长,影响编写,更影响阅读。如果某一行代码过长,我们将会换行书写,这样就会避免某一行太过冗长。换行时不能影响程序的编写,不改变程序的实际意图,比如&&这个字符肯定不能写在两行。

8.断行与空白的{}行

按照如下标准:

if (判断条件)

{

      代码块;

}

else

{

      代码块;

}

9.命名

让每一个变量名、函数名都有含义,不能让读程序的人读不懂程序。每一个变量都有实际含义,增强可读性。

10.运算符

运算符不要做标准语义之外的任何动作,由于我们的编程能力有限,我们也不自己定义运算符。

11.代码结构化

把能够重用的代码块,单独提出来写到一个函数里,然后能够将这些代码重用。

12.参数处理

对外部传来的参数,要验证其正确性。

要求二

1.在给变量名命名时,我们出现了小部分没有意义的变量,由于不能让每个变量都具有实际含义,在实现功能四的时候,我们程序里出现了几个没有意义的变量名,其他函数里也出现了个别没有意义的变量(对应9.命名)

2.我们出现2次了代码行宽过长的现象,但出于可读性的考虑,我们没有修改(对应7.行宽)

3.变量名首字母都采用大写,但编写时偶尔会出现首字母不大写的情况,例如data,经过考虑,我们决定允许部分单个单词组成的变量首字母小写。(对应1.大小写)

4.我们应该多添加注释,方便理解(对应2.注释)

5书写习惯不同,有时候不能完全按照此前规定的缩进,我们对此不进行约束(对应3.缩进)

6.由于书写习惯,有些行会出现多个变量写在同一行的问题,所以我们决定废除第四条。(对应4.分行)

7.在重用代码时发生了逻辑错误,我们决定废除此条。(对应11.代码结构化)

8.编程时由于忽略了参数处理,导致我们在对命令行参数处理时发生错误,所以我们决定废除此条。(对应12.参数处理)

9.我们在编写程序时,会忽略在循环结构和条件语句后加入括号,这种行为很容易导致错误的发生,我们以后会严格遵守。(对应5.括号)

posted @ 2018-10-08 11:21  朱珅莹  阅读(117)  评论(0编辑  收藏  举报