《第7部分 程序格式与规范.ppt》由会员分享,可在线阅读,更多相关《第7部分 程序格式与规范.ppt(40页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、高级语言程序设计课程作业编码规范C语言北京交通大学计算机与信息技术学院为什么要这么做?n书写良好的代码更容易阅读n容易阅读的代码才容易被理解n容易被理解的代码才健康n编程风格体现了程序员对语言的理解水平n求职:好的编程风格给别人良好的第一印象,是获得高薪的第一步1.编写目的n通过编程规范的学习和强制执行,使同学们从一开始就接触基本的软件开发思想,了解基本的软件工程规范,养成良好的编程习惯;为后续课程的实践环节和日后实际工作打下良好的基础;也便于教师批改与回复电子作业。n执行良好的编码规范可以使编写出来的程序易于阅读、理解和管理。2.编码规范的定义n编码(coding):是指用适当的代码编写工具
2、编写C语言程序的源代码n编码规范:n相关英文说法:coding standard,coding convention,coding criterionn是指被普通采用的、或由某个企业或机构规定的,用计算机语言编写程序的过程中需要遵守的一套规则或约定的集合n编码规范并不是语言的语法规则3.编码规范的应用n在软件业高速发展、团队开发成为基本开发模式的今天,几乎每个软件企业或软件开发团队都会制定各种各样的规范,应用于软件开发过程的各个环节中,编码规范是最基础规范之一。n不同的公司,对同一种开发语言,一般都采用类似的规范,也就是说编码规范具有一些通用性的标准4.编码规范的学习和执行n要求学习和掌握规范
3、标准n要求在本课程的作业过程中执行这些规范,上交的电子作业必须符合这些规范要求n要求在后续相关课程中执行此规范中的基本部分,并根据后续课程内容要求执行相应的扩展规范 C语言编码规范Coding standards1.文件级模块说明规范File module specification文件级模块说明规范的含义n模块定义:指以独立的文件形式存在的模块,主要包括两类nC或C+的扩展名为.c或.cpp的源代码文件模块,例如abc.cpp,扩展名为.h的头文件模块,如abc.h,exam.hn对于任何一个用户新建的模块,必须按规范要求给出模块的相关描述信息文件级模块说明的构成n文件级模块说明至少应由以下
4、部分构成n1.模块的作者信息n2.模块的版权声明n3.模块的名称n4.模块的摘要描述n5.模块的其它说明n6.模块的历史信息文件级模块说明的编写n1.每个用户的文件级代码模块必须编写一个说明n2.模块说明要求以注释的形式出现在模块的首部n3.为了减少每次的工作,每个人应先编写好不变部分,每新建一个模块将不变部分复制到文件首部,再行更改可变部分中文版文件级模块说明规范/*作者信息:姓名:学号:班级:学院:Email:电话:版权声明:模块名称:本模块详细名称,不是文件名摘要:摘要地描述本模块的功能其它说明:可有可无,有关本模块的附加说明,这些说明可以在以后帮助代码的阅读者理解这个模块里的内容,如:
5、算法的描述,特殊情况,参考资料等模块历史:谁于某年某月某日创建本模块,创建人email 谁于某年某月某日修改本模块,修改人email 修改原因:可有可无,根据需要添加*/例子/*作者信息:姓名:张三 学号:06123456 班级:计科0601班 学院:计算机 Email: 电话:51689999版权声明:版权由张三所有,除老师外,未经允许不得拷贝本人作业模块名称:第一个模块摘要:本模块是我的第一个C语言作业,实现了一些简单的功能其它说明:无模块历史:张三于2006年9月20日创建本模块,email:张三于2006年9月25日修改本模块,email:同上 修改原因:增加了一个输出正方形的函数*/
6、注意:红色部分为必填部分,缺填红色部分可能导致作业无法得到批阅注释开始注释结束/*作者信息:姓名:张三 学号:06123456 班级:计科0601班 学院:计算机 Email: 电话:51689999版权声明:版权由张三所有,除老师外,未经允许不得拷贝本人作业模块名称:第一个模块摘要:本模块是我的第一个C语言作业,实现了一些简单的功能其它说明:无模块历史:张三于2006年9月20日创建本模块,email:张三于2006年9月25日修改本模块,email:同上 修改原因:增加了一个输出正方形的函数*/#include“stdio.h”#include“string.h”/*main函数说明*/m
7、ain().模块说明示例:example.cppEnglish Version/*Author Info:Name:Author ID:Class:School:Email:Tel.Copyright(c)2005 NJTUModule Name:An unabbreviated name for the module(not the filename)Abstract:Description of what this module doesNotes:Optional Additional notes about this module-things that may help the re
8、ader of this code later on.Examples are:algorithm description,special case conditions,references,etc.History:Created on mm/dd/yyyy by email-name Modified on mm/dd/yyyy by email-name Optional history description*/2.函数说明规范Function Specification关于函数说明n对于作业中程序的任何一个函数,包括main函数,都需要写出函数的说明n一个良好的编程习惯:n写任何一个
9、函数以前,第一步工作就是先把函数说明写出来,而不是直接先写代码函数说明规范/*函数名称:写出函数的名称功能描述:描述出函数具有的功能函数参数:输入输出参数说明,对每个参数都需要作出仔细说明返回值:返回值说明,或者标明无回值模块历史:谁于某年某月某日创建本模块,创建人email 谁于某年某月某日修改本模块,修改人email 修改原因:可有可无,根据需要添加*/例子/*函数名称:main功能描述:输出 Hello world!函数参数:无返回值:无模块历史:张三于2006年9月20日创建本模块,email:*/void main()printf(Hello world!);English Vers
10、ion/*Function Name:Function Description:Description of what the function doesArguments:|OUT|IN/OUT argument-name-description of argument Return Value:return-value-description of return value or NONEHistory:Created on mm/dd/yyyy by email-name*/3.代码注释恰到好处的注释n1.对重要变量说明其作用;n2.对每一段函数代码加注释说明功能;n3.对重要的语句加注
11、释说明其功能;n4.对重要的函数调用的参数加实际参数说明;n5.在自己认为必要的地方加上注释n6.可以采用/*/和/进行注释4.基本编辑规范要求正确使用:缩进,空格,空行缩进n根据语句间的层次关系采用缩进格式书写程序,每进一层,往后缩进一层n函数内的变量声明与执行语句要缩进一层n缩进长函数调用语句pMsg=ComReadMsgFromQueue(aServer,NULL,ComWait_c,lTimeOut);n一个缩进层次为四个英文字符宽度n一般用Tab键进行缩进,定义Tab为四个英文字符宽度n许多开发工具编辑器如VC一般会自动帮你缩进要加空格的场合n1.在逗号后面和语句中间的分号后面加空格
12、,如:nint i,j,k;nfor(i=0;i b a 左右两加不加空格:pStud-szName,Student.nIDn2.不要在行尾加多余的空格或Tabn3.函数名与左括号之间不要加空格:func()n4.指针说明符号*与变量名间不要加空格:nint*pInt;不要写成:int*pInt;n5.复合运算符中间不能加空格,否则会产生语法错误,如:na+=b a =b 都是错误的空行与换行n1.函数的变量说明与执行语句之间加上空行;n2.每个函数内的主要功能块之间加空行表示区隔;n3.一行语句不要写的太长,将长语句分成多行写;n4.不要在一行中写多条语句.例子int main()int i
13、,j,nSum=0;/变量说明 for(i=0;i 10;i+)/执行代码 for(j=0;j 10;j+)nSum+=i;注意空格空行注意各层缩进5.标识符命名Naming Indentifiers标识符命名基本要求n1.这里所指的标识符包括符号常量、变量、函数名、类型名、成员名、C+中的类名等需要编程者命名的各种文字符号n2.标识符命名必须符合语法规则n3.任何标识符的命名最好能有一定的含义n4.标识符的命名尽量采用英文5.1 符号常量命名规范n符号常量的命名用大写字母表示n如n#define LENGTH 10n如果符号常量由多个单词构成,两个不同的单词之间可以用下划线连接n如n#def
14、ine MAX_LEN 505.2 变量命名普通规范n1.变量名一般需要反映变量的用途n如:nint sum;n2.如果变量名由多个单词构成,每个单词的首字符要大写n如:nint TotalFiles;5.3 变量命名与变量类型n在实际软件开发中,常见的规范强制要求能从变量名中看出变量的类型,因此,建议同学们一开始就养成这样的习惯。n使变量能反映类型的方法是在变量的前面加上各种前缀,由这些前缀反映变量的类型n对类型前缀规范,各种不同的软件开发环境可能会有不同规范,不同的软件企业或开发团队,也可能会有不同的规范,没有绝对的标准,但是这些规范都大同小异。5.4 C常见变量前缀建议规范类型前缀范例i
15、ntn 或 iint nSum,iSum;charchchar chTemp;doubleddouble dSum;floatflfloat flSum;char*szchar*szBuffer;char szchar szBuffer100;pointpint*pnBuffer;pointer to pointerppint*ppnBuffer;arrayarr 或 rgint narr10,nrg10;5.5 关于C+命名规范n在各种C+中,还有许多不同类型的标识符前缀,包括模块成员、全局变量等其它供参考C+前缀规范sSHORTSigned integer,16-bit.lLONGSign
16、ed integer,32-bit.usUSHORTUnsigned integer,16-bit.ulULONGUnsigned integer,32-bit.bBYTENon-counting purposes,8-bit allocation.wWORDNon-counting purposes,16-bit allocation.dwDWORDNon-counting purposes,32-bit allocation.iintScalable signed integer uUINTScalable unsigned integerflfloatFloating point,32-
17、bit,6-7 significant digits.其它供参考C+规范ddoubleFloating point,64-bit,15-16 signigicant digits.chCHARCharacter,8-bit.wchWCHARCharacter,Unicode,16-bit.tchTCHARCharacter,flexible Unicode or DBCS.fnFunctionFunction:always used with a type prefix(eg:pfn is pointer to function).vvoidVoid:always used with a type prefix(eg:pv is pointer to void).fbool or BOOLf means flagvarVARIANT or variant_t6.其它一些小技巧和要求n函数一般情况下应该少于100行n函数定义一定要包含返回类型,没有返回类型加voidn函数调用如果过长,则每个实参分别占一行n写比较表达式时,将常量放在左边n10=nnNULL!=pIntn指针变量总是要初始或重置为NULLn使用包含复合语句,即使是只有一行,如:nif(1=a)n x=5;n本规范到此结束
限制150内