版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、C/C+源代码书写规范,1,1. 在.h/.cpp的开头应有一段格式统一的说明,内容包括: a. 文件名 (FileName); b. 创建人 (Creator); c. 文件创建时间 (Date); d. 简短说明文件功能、用途 (Comment,2,例: / / / FileName: GetVersion.h / Creator: Liu Haifeng / Date: 2002-10-28 / Comment: Get file version information,3,2.对于主要功能函数应有注释说明。内容包括:功能、入口/出口参数,必要时还可有备注或补充说明,对于函数中的主要功能
2、代码,也应有注释说明。注释以英文为主,4,例: /Remarks: / Check file whether exist / /Parameters: / LPCTSTR lpszPathName : Input full path name / /Return values: / int : Non-zero means success / Zero means failure,5,3. 每列代码的长度推荐为80列,最长不得超过120列;折行以对齐为准。 例:HANDLE KSOpenFile(const char cszFileName, int nMode); 或者: BOOL KSRe
3、adFile( HANDLE hFile, void *pvBuffer, int nReadSize, int *pnReadSize,6,4. 循环、分支代码,判断条件与执行代码不得在同一行上。 例:正确: if (n = -2) n = 1; else n = 2; 不得写做: if (n = -2) n = 1; else n = 2,7,5. 指针的定义,* 号既可以紧接类型,也可以在变量名之前。 例:可写做: int* pnsize; 也可写做:int *pnsize; 但不得写做:int * pnsize,8,6. 在类的成员函数内调用非成员函数时,在非成员函数名前必须加上:。
4、例::Sleep(2000,9,7. 函数入口参数有缺省值时,应注释说明。 例: BOOL KSSaveToFile( const char cszFileName, BOOL bCanReplace /* = TRUE */ ); 或者: BOOL KSSaveToFile( const char cszFileName, BOOL bCanReplace / = TRUE,10,8. else if 必须写在一行,11,9. 与、有关的各项规定: 9.1、应独占一行。在该行内可有注释。 例:正确: for (i = 0; i cbLine; i+) / . printf(Line %d:,
5、 i); printf(%sn, pFileLines); 不得写做: for (i = 0; i cb; i+) printf(Line %d:, i); printf(%sn, pFileLines);,12,9.2必须另起一行,之后的代码必须缩进一个Tab。与必须在同一列上。 例:正确: if (i 0) m = 1; n+;,13,不得写做: if (i 0) m = 1; n+; 例外: if (i = 0) ASSERT(FALSE); return;,14,9.3 在循环、分支之后若只有一行代码,虽然可省略、,但不推荐这么做。若省略后可能引起歧义,则必须加上、。 例:正确: if
6、 (n = -2) n = 1; Else n = 2,15,或者: if (n = -2) n = 1; else if (n != nTemp) n = 2; else n = 3;,16,不得写做: if (n = -2) n = 1; else if (n != nTemp) n = 2; else n = 3,17,不推荐: if (i 1) n = 3;,18,10. 与空格有关的各项规定。 10.1 在所有两目、三目运算符的两边都必须有空格。在单目运算符两端不必空格。但在-、:、.、等运算符前后,及 for (int i = nMinLine; i = nMaxLine; i+)
7、 不得写做: int n=0, nTemp; for ( int i=nMinLine; i=nMaxLine; i+,20,10.2 for、while、if 等关键词之后应有1个空格,再接(,之后无空格;在结尾的)前不得有空格。 例:正确: if (-2 = n) 不得写做: if(-2 = n) 或 if ( -2 = n ) 等等,21,10.3 调用函数、宏时,(、)前后不得有空格。 例:正确: printf(%dn, nIndex); 不得写做: printf (%dn, nIndex); printf( %dn, nIndex ); 等等,22,10.4 类型强制转换时,()前后
8、不得有空格 例:可写做: (KSFile*)pFile; 也可写做: (KSFile *)pFile 不得写做: ( KSFile* )pFile ( KSFile * ) pFile,23,11. 与缩进有关的各项规定 11.1 缩进以 Tab 为单位。 1 个 Tab 为 4 个空格 11.2 下列情况,代码缩进一个 Tab: 1. 函数体相对函数名及、。 例: int Power(int x) return (x * x);,24,2. if、else、for、while、do 等之后的代码。 3. 一行之内写不下,折行之后的代码,应在合理的位置进行折行。若有 + - * / 等运算符,
9、则运算符应在上一行末尾,而不应在下一行的行首,25,11.3 下列情况,不必缩进:switch 之后的 case、default。 例: switch (nID) case ID_PLAY: . break; case ID_STOP: . break; default: . break;,26,12.对于涉及到系统的功能调用,要求使用系统提供的宏,不得直接使用具体的数值。 例: char szSystemPathMAX_PATH = 0; 正确 char szSystemPath260 = 0; 错误,27,13.关于函数编写的规定 13.1 除了非常简单的函数或者没有必要,函数需要有返回值
10、,并且推荐 返回值的类型为int,成功时为 true,失败时为false。不推荐直接使用1和0来表示。 13.2 在函数内部变量定义全部放在函数的开始处,不能在代码中间出现 变量定义。变量定义需要初始化值,一般是0、false、NULL等,28,13.3 程序员自行编写的函数不推荐使用DWORD等指明字节长度的变量 类型,推荐使用unsigned long等变量类型。对于ULONG等vc系统定义的变量类型,推荐使用unsigned long 来代替。如果调用系统API,在MSDN中已经指明了是DWORD等类型,则可以使用。 13.4 推荐使用int nResult作为函数自身的返回值变量,int nRetCode、BOOL bRetCode作为调用其他函数的返回值变量,29,13
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2024年度演艺经纪合同:艺人经纪公司与合作演员之间的演艺活动安排与分成(2024版)3篇
- 房产财产抵押担保合同2024年度修订2篇
- 2024年度电商平台运营推广合作合同的标的和具体描述3篇
- 柴油运输服务合同
- 吊篮安装拆卸施工合同
- 养殖场地租赁合同怎样写
- 2024年度建筑工程消防系统安装合同2篇
- 2024年度智能交通系统建设与运营合作协议2篇
- 2024年度商标转让合同标的及商标权属变更3篇
- 2024年度货运代理服务合同具体描述与服务内容
- 6人小品《没有学习的人不伤心》台词完整版
- 《注册建造师执业工程规模标准》
- 《王戎不取道旁李》课件完美版
- 口腔科诊断证明书模板
- 论现代企业人力资源管理中激励机制的应用以腾讯公司为例
- CRRT治疗剂量的计算
- (完整)风景园林概论知识点,推荐文档
- 烟草专卖局(公司)员工考核管理办法
- 实验室间比对方案
- 面神经炎(面瘫病)病程模板
- 主斜井维修、刷扩安全技术措施
评论
0/150
提交评论