软件开发规范

更新时间:2023-07-08 18:17:24 阅读: 评论:0

软件开发规范
(试行版)
    在团队协作开发的情况下,编程时应该强调的一个重要方面是程序的易读性,在保证软件的速度等性能指标能满足用户需求的情况下,能让其他程序员容易读懂你的程序。一套鲜明的编程风格,可以让协作者、后继者和自己一目了然,在很短的时间内看清程序的结构,理解设计的思路。大大的提高代码的可读性、可重用性、程序健壮性、可移植性和可维护性。
    制定本编程规范的目的是为了提高软件开发效率及所开发的软件的可维护性,提高软件的质量。本规范由程序风格、命名规则、注释规范、程序健壮性、可移植性、错误处理以及软件的模块化规范等部分组成。
一、程序风格:
  1、严格采用阶梯层次组织程序代码:
各层次缩进的分格采用VC的缺省风格,即每层次缩进为4格,括号位于下一行。要求相匹配的大括号在同一列,对继行则要求再缩进4格。例如:
    void main()
        {
            ......
        long lI;    //循环变量
            long lSum;//用来记录和
            float fAvg;//用来求平均值
        ......
            //对数进行累加。
            for( lI=0;lI<10;lI++)
        {
                lSum=lSum+lI;
            ......        }
            //求平均值。
        fAvg=lSum/10.0;
            ......
    }
      2、提示信息字符串的位置
在程序中需要给出的提示字符串,为了支持多种语言的开发,除了一些给调试用的临时信息外,其他所有的提示信息必须定义在资源中,以利于翻译成多种语言,以便多版本共用一套代码。
腰背疼
3、对变量的定义,尽量位于函数的开始位置。
二、命名规则:
1、变量名的命名规则
①、变量的命名规则要求用“匈牙利法则”。即开头字母用变量的类型,其余部分用变量的英文意思或其英文意思的缩写,尽量避免用中文的拼音,要求单词的第一个字母应大写。
            即: 变量名=变量类型+变量的英文意思(或缩写)
        对非通用的变量,在定义时加入注释说明,变量定义尽量可能放在函数的开始处。
    见下表:
        bool(BOOL)                    用b开头              bIsParent
    byte(BYTE)                  用by开头                byFlag
    short(int)              n开头                nStepCount
        long(LONG)                用l开头                lSum
    char(CHAR)                  用c开头                cCount
    float(FLOAT)              用f开头                fAvg
    double(DOUBLE)            用d开头                dDeta
void(VOID)              v开头              vVariant
unsigned intWORD        w开头                wCount
unsigned long(DWORD)        dw开头            dwBroad
HANDLE(HINSTANCE)        用h开头                hHandle
DWORD                    用dw开头            dwWord
LPCSTR(LPCTSTR)            str开头            strString
0结尾的字符串            阳光的作文sz最大的数开头          szFileName
对未给出的变量类型要求提出并给出命名建议给技术委员会。
②、指针变量命名的基本原则为:
对一重指针变量的基本原则为:
        “p”+变量类型前缀+命名
如一个float*型应该表示为pfStat
对多重指针变量的基本规则为:
    二重指针:  “pp”+变量类型前缀+命名
    三重指针:  “ppp”+变量类型前缀+命名
    ......
③、全局变量用g_开头,如一个全局的长型变量定义为g_lFailCount,即:变量名=g_+变量类型+变量的英文意思(或缩写)
④、静态变量用s_开头,如一个静态的指针变量定义为s_plPerv_Inst,即: 变量名=s_+变量类型+变量的英文意思(或缩写)
⑤、成员变量用m_开头,如一个长型成员变量定义为m_lCount;即:变量名=m_+变量类型+变量的英文意思(或缩写)
2、 数的命名规范:
函数的命名应该尽量用英文表达出函数完成的功能。遵循动宾结构的命名法则,函数名中动词在前,并在命名前加入函数的前缀,函数名的长度不得少于8冬瓜子的作用个字母
公司岗位有哪些例如:
    long cmGetDeviceCount(……);
3、函数参数规范:
1、 参数名称的命名参照变量命名规范。
2、 为了提高程序的运行效率,减少参数占用的堆栈,传递大结构的参数,一律采用指针或引用方式传递。
3、 为了便于其他程序员识别某个指针参数是入口参数还是出口参数,同时便于编译器检查错误,应该在入口参数前加入const标志。如:
……cmCopyString(const char * c_szSource,  char * szDest)
4、引出函数规范:
对于从动态库引出作为二次开发函数公开的函数,为了能与其他函数以及Windows的函数区分,采用类别前缀+基本命名规则的方法命名。例如:在对动态库中引出的一个图象编辑的函数定义为 imgFunctionname(其中imgimage缩写)
现给出三种库的命名前缀:
1、 对通用函数库,采用cm为前缀
2、 生命如一泓清水对三维函数库,采用vr为前缀
3、 对图象函数库,采用img为前缀
对宏定义,结果代码用同样的前缀
    5、文件名(包括动态库、组件、控件、工程文件等)的命名规范:
文件名的命名要求表达出文件的内容,要求文件名的长度不得少于5个字母严禁使用象file1,myfile之类的文件名。
三、注释规范:
1、函数头的注释
对于函数,应该从“功能”,“参数”,“返回值”、“主要思路”、“调用方法”、“创建日期”、“维护记录”六个方面用如下格式注释:
////GeoView_Tech_Mark_Begin    用于自动提技术开发文档的标识
//================================================================//
/
/GeoView_Doc_Mark_Begin        用于自动提二次开发文档的标识
//            函数名:bStrRemove
//          功能:  从一个String 中删除另一个String。
//            参数:  strByDelete,strToDelete
//            (入口) strByDelete:  被删除的字符串(原来的字符串)
名声英语//            (出口) strToDelete:  要从上个字符串中删除的字符串。
//            返回: 找到并删除返回1,否则返回0。(对返回值有错误编码的要//                求列出错误编码)。
//            调用方法:BOOL bResult=bStrRemove(strByDelete,strToDelete);
//GeoView_Doc_Mark_End        用于自动提取文档的标识
//            主要思路:本算法主要采用循环比较的方法来从strByDelete中找到
//                  与strToDelete相匹配的字符串,对多匹配strByDelete
//                  中有多个strToDelete子串)的情况没有处理。请参阅:
//                  书名......
//            创建日期:2002/10/9    田宜平
//            修改日期:2002/10/10  何珍文  (并将该日期写在代码中便于查阅)
//================================================================//
函数名(……)
////GeoView_Tech_Mark_End  用于自动提技术开发文档的标识
{
    ……
}
1、 对于某些函数,其部分参数为传入值,而部分参数为传出值,所以对参数要详细说明该参数是入口参数,还是出口参数,对于某些意义不明确的参数还要做详细说明(例如:以角度作为参数时,要说明该角度参数是以弧度(PI),还是以度为单位),对既是入口又是出口的变量应该在入口和出口处同时标明。等等。
2、 函数的注释应该放置在函数的头文件中,在实现文件中的该函数的实现部分应该同时放置该注释。
3、 在注释中应该详细说明函数的主要实现思路、特别要注明自己的一些想法,如果有必要则应该写明对想法产生的来由。对一些模仿的函数应该注释上函数的出处。
4、 在注释中详细注明函数的适当调用方法,对于返回值的处理方法等。在注释中要强调调用时的危险方面,可能出错的地方。
5、 对修改日期的注释要求记录整个修改过程和修改人。
如果算法比较复杂,或算法中的变量定义与位置有关,则要求对变量的定义进行图解。对难以理解的算法能图解尽量图解。
2、变量的注释:
对于变量的注释紧跟在变量的后面说明变量的作用。原则上对于每个变量应该注释,但对于意义非常明显的变量,如:i,j等循环变量可以不注释。
例如: long lLineCount;  //线的根数。
     3、文件的注释:
文件应该在文件开头加入以下注释:
/////////////////////////////////////////////////////////////////////
//          工程: 文件所在的项目名。
//              作者:田宜平,修改者:何珍文
//              描述: 说明文件总的功能。
//              创建日期:    说明文件的创建日期。
//              修改:    说明对文件的修改内容、修改原因以及修改日期。
//              参考文献: ......
/////////////////////////////////////////////////////////////////////
为了防止头文件被重复包含要求对头文件进行定义如下:
    #ifndef __FILENAME_H__
#define __FILENAME_H__
其中FILENAME为头文件的名字。
   4、其他注释:
日本电影老师在函数内我们不需要注释每一行语句。但必须在各功能模块的每一主要部分之前添加块注释,注释每一组语句,在循环、流程的各分支等,尽可能多加以注释。
    其中的循环、条件、选择等位置必须注释。
    对于前后顺序不能颠倒的情况,建议在注释中增加序号。
例如:
......
//1、......注释
for (......)
{
}
if(......)
{//......注释
}
el
{//......注释
}
//......注释
switch(......)
{
ca: ......// ......注释
......
ca: ......// ......注释

本文发布于:2023-07-08 18:17:24,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/fan/89/1073305.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:变量   函数   注释   命名   参数   要求
相关文章
留言与评论(共有 0 条评论)
   
验证码:
推荐文章
排行榜
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图