C++函数命名规则

转自:http://blog.csdn.net/rocksword/article/details/10104533

1、严格采用阶梯层次组织程序代码:    
    各层次缩进的分格采用VC的缺省风格,即每层次缩进为4格,括号位于下一行。要求相匹配的大括号在同一列,对继行则要求再缩进4格。例如:    
    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    int(WORD)    用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_+变量类型+变量的英文意思(或缩写)    
    ⑥、对枚举类型(enum)中的变量,要求用枚举变量或其缩写做前缀。并且要求用大写。    
    如:enum    cmEMDAYS    
    {    
    EMDAYS_MONDAY;    
    EMDAYS_TUESDAY;    
    ……    
    };    
    ⑦、对struct、union、class变量的命名要求定义的类型用大写。并要加上前缀,其内部变量的命名规则与变量命名规则一致。    
    结构一般用S开头    
    如:struct    ScmNPoint    
    {    
    int    nX;//点的X位置    
    int    nY;    //点的Y位置    
    };    
    联合体一般用U开头    
    如:    union    UcmLPoint    
    {    
    long    lX;    
    long    lY;    
    }    
    类一般用C开头    
    如:    
    class    CcmFPoint    
    {    
    public:    
    float    fPoint;    
    };    
    对一般的结构应该定义为类模板,为以后的扩展性考虑    
    如:    
    template    
    class    CcmTVector3d    
    {    
    public:    
    TYPE    x,y,z;    
    };    
    ⑧、对常量(包括错误的编码)命名,要求常量名用大写,常量名用英文表达其意思。    
    如:#define    CM_FILE_NOT_FOUND    CMMAKEHR(0X20B)    其中CM表示类别。    
    ⑨、对const    的变量要求在变量的命名规则前加入c_,即:c_+变量命名规则;例如:    
    const    char*    c_szFileName;    
    2、    函数的命名规范:    
    函数的命名应该尽量用英文表达出函数完成的功能。遵循动宾结构的命名法则,函数名中动词在前,并在命名前加入函数的前缀,函数名的长度不得少于8个字母。    
    例如:    
    long    cmGetDeviceCount(……);    
    3、函数参数规范:    
    ①、    参数名称的命名参照变量命名规范。    
    ②、    为了提高程序的运行效率,减少参数占用的堆栈,传递大结构的参数,一律采用指针或引用方式传递。    
    ③、    为了便于其他程序员识别某个指针参数是入口参数还是出口参数,同时便于编译器检查错误,应该在入口参数前加入const标志。如:    
    ……cmCopyString(const    char    *    c_szSource,    char    *    szDest)    
    4、引出函数规范:    
    对于从动态库引出作为二次开发函数公开的函数,为了能与其他函数以及Windows的函数区分,采用类别前缀+基本命名规则的方法命名。例如:在对动态库中引出的一个图象编辑的函数定义为    imgFunctionname(其中img为image缩写)。    
    现给出三种库的命名前缀:    
    ①、    对通用函数库,采用cm为前缀。    
    ②、    对三维函数库,采用vr为前缀。    
    ③、    对图象函数库,采用img为前缀。    
    对宏定义,结果代码用同样的前缀。    
    5、文件名(包括动态库、组件、控件、工程文件等)的命名规范:    
    文件名的命名要求表达出文件的内容,要求文件名的长度不得少于5个字母,严禁使用象file1,myfile之类的文件名。    
三、注释规范:    
    1、函数头的注释    
    对于函数,应该从“功能”,“参数”,“返回值”、“主要思路”、“调用方法”、“日期”六个方面用如下格式注释:    
    //程序说明开始    
    //================================================================//    
    //    功能:    从一个String    中删除另一个String。    
    //    参数:    strByDelete,strToDelete    
    //    (入口)    strByDelete:    被删除的字符串(原来的字符串)    
    //    (出口)    strToDelete:    要从上个字符串中删除的字符串。    
    //    返回:    找到并删除返回1,否则返回0。(对返回值有错误编码的要//    求列出错误编码)。    
    //    主要思路:本算法主要采用循环比较的方法来从strByDelete中找到    
    //    与strToDelete相匹配的字符串,对多匹配strByDelete    
    //    中有多个strToDelete子串)的情况没有处理。请参阅:    
    //    书名......    
    //    调用方法:......    
    //    日期:起始日期,如:2000/8/21.9:40--2000/8/23.21:45    
    //================================================================//    
    函数名(……)    
    //程序说明结束    
    ①、    对于某些函数,其部分参数为传入值,而部分参数为传出值,所以对参数要详细说明该参数是入口参数,还是出口参数,对于某些意义不明确的参数还要做详细说明(例如:以角度作为参数时,要说明该角度参数是以弧度(PI),还是以度为单位),对既是入口又是出口的变量应该在入口和出口处同时标明。等等。    
    ②、    函数的注释应该放置在函数的头文件中,在实现文件中的该函数的实现部分应该同时放置该注释。    
    ③、    在注释中应该详细说明函数的主要实现思路、特别要注明自己的一些想法,如果有必要则应该写明对想法产生的来由。对一些模仿的函数应该注释上函数的出处。    
    ④、    在注释中详细注明函数的适当调用方法,对于返回值的处理方法等。在注释中要强调调用时的危险方面,可能出错的地方。    
    ⑤、    对日期的注释要求记录从开始写函数到结束函数的测试之间的日期。    
    ⑥、    对函数注释开始到函数命名之间应该有一组用来标识的特殊字符串。    
    如果算法比较复杂,或算法中的变量定义与位置有关,则要求对变量的定义进行图解。对难以理解的算法能图解尽量图解。    
    2、变量的注释:    
    对于变量的注释紧跟在变量的后面说明变量的作用。原则上对于每个变量应该注释,但对于意义非常明显的变量,如:i,j等循环变量可以不注释。    
    例如:    long    lLineCount    //线的根数。    
     3、文件的注释:    
    文件应该在文件开头加入以下注释:    
    /////////////////////////////////////////////////////////////////////    
    //    工程:    文件所在的项目名。    
    //    作者:**,修改者:**    
    //    描述:说明文件的功能。    
    //    主要函数:…………    
    //    版本:    说明文件的版本,完成日期。    
    //    修改:    说明对文件的修改内容、修改原因以及修改日期。    
    //    参考文献:    ......    
    /////////////////////////////////////////////////////////////////////    
    为了头文件被重复包含要求对头文件进行定义如下:    
    #ifndef    __FILENAME_H__    
    #define    __FILENAME_H__    
    其中FILENAME为头文件的名字。    
       4、其他注释:    
    在函数内我们不需要注释每一行语句。但必须在各功能模块的每一主要部分之前添加块注释,注释每一组语句,在循环、流程的各分支等,尽可能多加以注释。    
    其中的循环、条件、选择等位置必须注释。    
    对于前后顺序不能颠倒的情况,建议在注释中增加序号。    
    例如:    
    在其他顺序执行的程序中,每隔3—5行语句,必须加一个注释,注明这一段语句所组成的小模块的作用。对于自己的一些比较独特的思想要求在注释中标明。    
四、程序健壮性:    
    1、函数的返回值规范:    
    对于函数的返回位置,尽量保持单一性,即一个函数尽量做到只有一个返回位置。(单入口单出口)。    
    要求大家统一函数的返回值,所有的函数的返回值都将以编码的方式返回。    
    例如编码定义如下:    
    #define    CM_POINT_IS_NULL    CMMAKEHR(0X200)    
    :    
    :    
    建议函数实现如下:    
    long    函数名(参数,……)    
    {    
    long    lResult;    //保持错误号    
    lResult=CM_OK;    
    //如果参数有错误则返回错误号    
    if(参数==NULL)    
    {    
    lResult=CM_POINT_IS_NULL;    
    goto    END;    
    }    
    ……    
    END:    
    return    lResult;    
    }    
    2、关于goto的应用:    
    对goto语句的应用,我们要求尽量少用goto语句。对一定要用的地方要求只能向后转移。    
    3、资源变量的处理(资源变量是指消耗系统资源的变量):    
    对资源变量一定赋初值。分配的资源在用完后必须马上释放,并重新赋值。    
    4、对复杂的条件判断,为了程序的可读性,应该尽量使用括号。    
    例:if(((szFileName!=NULL)&&(lCount>=0)))||(bIsReaded==TRUE))    
  
五、可移植性:    
    1、高质量的代码要求能够跨平台,所以我们的代码应该考虑到对不同的平台的支持,特别是对windows98和windowsnt的支持。    
    2、由于C语言的移植性比较好,所以对算法函数要求用C代码,不能用C++代码。

3、对不同的硬件与软件的函数要做不同的处理

时间: 2024-08-30 00:36:25

C++函数命名规则的相关文章

MS SQL开发命名规则

下面的SQL开发命名规则是我自己开发时总结.整理出来的,以后的开发过程中将不断完善.修改.也希望各位网友指点.批判. 纲领: SQL 语句关键字全部大写, 命名规则建议使用Pascal Case 或 每个单词使用下划线_隔开,不建议全部使用小写.尽量少使用特殊字符比如数字.空格等 使用英文或英文缩写,不建议使用拼音.尽量见名知意. 1:    数据库名命名规则 (1.1)  数据库名用产品名称或项目名称   尽量用名词,见名知意 :MyAssistant  我的个人助手            

[转]程序开发基础学习二(C++ Google Style 命名规则)

无规矩不成方圆,新的岗位就需要服从团队的编码规则.很开心团队用的是Google的C++编码规则,大概看了下Google 的编码规则,正如九天翔雁说的:“Google的 C++ Style Guide远不仅是一个传统意义上的代码书写风格指导,对于C++的方方面面做出了Google的解释和使用建议,包括每个规则给出时,较为详细的讲了这个规则好的一面和不好的一面,最最激进的规则甚至有禁用C++的异常,以及除了Google规范的Interface作为基类外,禁用多重继承,在绝大部分情况下禁用默认参数等内

C语言中变量名及函数名的命名规则与驼峰命名法

一.C语言变量名的命名规则:(可以字母,数字,下划线混合使用) 1. 只能以字母或下划线开始:2. 不能以数字开始:3. 一般小写:4. 关键字不允许用(eg:int float=2//error  float 为保留字不允许用): 二.函数名的命名规则 1.见名知意:2.自定义函数函数名首字母大写(库函数里的函数名都是以小写字母定义,为了区分库函数和自定义函数,避免冲突). 三.宏定义里面的变量 全大写 eg:#define SIZE 100(后面函数所有出现的SIZE全用100代替,它在所有

标示符(变量名、类名、函数名、常量名等)命名规则

由26个英文字母大小写,数字:0-9,符号:_.$组成. 规则: 1.数字不可以开头 2.不可以使用关键字 例如:class就不可以,因为class是关键字. 3.不可以包含“_.$”以外的特殊符号,例如:“DemoTest”就不可以,其中的空格就是特殊符 号. 一些常用命名规则: 包名:多单词组成时所有字母都小写. 例如:xxxyyyzzz    类名接口名:多单词组成时,所有单词的首字母大写.例如:XxxYyyZzz变量名和函数名:多单词组成时,第一个单词首字母小写,

PHP语言的命名规则

想要了解和掌握一门编程语言,我觉得掌握它的命名规则很重要.不成规矩不成方圆,编程也是一样,不仅要你自己能看懂,别人也要可以看懂你的代码,这就需要掌握该门语言的命名规则.从程序员自己编写代码使用的命名规则,就可以一眼看出这个程序员的技术水平如何.本文和大家分享的就是php语言的命名规则,希望可以帮助大家更好的学习php ,一起来看看吧. 就一般约定而言,类.函数和变量的名字应该是能够让代码阅读者能够容易地知道这些代码的作用,应该避免使用凌磨两可的命名. 1. 类命名 ①使用大写字母作为词的分割,其

详解 Python 中的下划线命名规则

在 python 中,下划线命名规则往往令初学者相当 疑惑:单下划线.双下划线.双下划线还分前后……那它们的作用与使用场景 到底有何区别呢?今天 就来聊聊这个话题. 1.单下划线(_) 通常情况下,单下划线(_)会在以下3种场景中使用: 1.1 在解释器中: 在这种情况下,“_”代表交互式解释器会话中上一条执行的语句的结果.这种用法首先被标准CPython解释器采用,然后其他类型的解释器也先后采用. >>> _ Traceback (most recent call last): Fil

PHP命名规则

就一般约定而言,类.函数和变量的名字应该是能够让代码阅读者能够容易地知道这些代码的作用,应该避免使用凌磨两可的命名. 1.  类命名 使用大写字母作为词的分割,其他的字母均使用小写. 名字的首字母使用大写. 不要使用下划线('_'). 如:Name.SuperMan.BigClassObject. 2. 类属性命名 属性命名应该以字符‘m’为前缀. 前缀‘m’后采用与类命名一致的规则. ‘m’总是在名字的开头起修饰作用,就像以‘r’开头表示引用一样. 如:mValue.mLongString等

thinkphp学习笔记1—目录结构和命名规则

最近开始学习thinkphp,在下不才,很多的问题看不明白所以想拿出来,恕我大胆发在首页上,希望看到的人能为我答疑解惑,这样大家有个互动,学起来快点,别无他意,所谓活到老,学到老,希望各位不要见笑啊. 我的做法很简单,先从手册开始,手册是开发thinkphp作者辛勤劳动的成果,但是有些地方是在是不懂,如果有幸各位也遇到类似的问题希望能回复.thinkphp手册地址:http://doc.thinkphp.cn/manual.html 1.框架目录 在章节1.6 目录结构,内容如下: 新版的目录结

thinkphp5中上传文件自定义命名规则

在thinkphp5中:有上传文件一章: https://www.kancloud.cn/manual/thinkphp5/155159 如果对于文件上传这一章,不了解,就先看下面的,再来看这一段. 下面我们自定义两个规则. 1.datea规则,年月/时分秒.(3位随机数) /201706/164030789 2.ymmd5规则,年/月/md5 修改框架文件:thinkphp/library/think/File.php. 增加两个case: case 'datea': case 'ymmd5'