常见命名法:

匈牙利命名法:基本原则是:变量名=属性+类型+对象描述\color{blue}{变量名=属性+类型+对象描述}变量名=属性+类型+对象描述,其中每一对象的名称都要求有明确含义,可以取对象名字全称或名字的一部分。命名要基于容易记忆容易理解的原则。保证名字的连贯性是非常重要的。

Camel命名法:即骆驼式命名法,原因是采用该命名法的名称看起来就像骆驼的驼峰一样高低起伏。Camel命名法有两种形式:混合使用大小写字母和单词之间加下划线\color{blue}{混合使用大小写字母和单词之间加下划线}混合使用大小写字母和单词之间加下划线,例如runFast和run_fast都属于Camel命名法。

Pascal命名法:与Camel命名法类似,不过Pascal命名法的首字母为大写字母。

命名通则:

1、在所有命名中,都应使用标准的英文单词或缩写\color{blue}{英文单词或缩写}英文单词或缩写。不得使用拼音或拼音缩写,除非该名字描述的是中文特有的内容,如半角、全角, 声母、韵母等。
2、所有命名都应遵循望文知义原则,即名称应含义清晰、明确。 3、所有命名都不易过长,应控制在规定的最大长度以内。
4、所有命名都应尽量使用全称。
5、如果命名使用缩写,则应该使用《通用缩写表》(见附录)\color{blue}{《通用缩写表》(见附录)}《通用缩写表》(见附录)中的缩写;原则上不推荐使用《通用缩写表》以外的缩写,如果使用,则必须对其进行注释和说明。

个人整合的具体规范:

1、工程名&命名空间:

  • 工程名不强制统一。
  • 命名空间成员名一律小写,最好使用一个单词或者一个缩写。

2、文件名:

  • 基于工程名,开头3个字母应表明与哪一个工程相关\color{blue}{开头3个字母应表明与哪一个工程相关}开头3个字母应表明与哪一个工程相关。 ·后面的字母应能够区别不同的功能。
  • 文件名的每个单词首字母均大写\color{blue}{每个单词首字母均大写}每个单词首字母均大写
  • 长度不限于8.3格式,建议不多于30个字符\color{blue}{建议不多于30个字符}建议不多于30个字符。
  • 若文件用于定义和实现类,建议文件名与类名保持一致\color{blue}{若文件用于定义和实现类,建议文件名与类名保持一致}若文件用于定义和实现类,建议文件名与类名保持一致。

3、函数名:

  • 参照 Windows API 的命名规范。
  • 推荐使用动宾结构。\color{blue}{推荐使用动宾结构。}推荐使用动宾结构。函数名应清晰反映函数的功能、用途。
  • 函数名最长不得超过30个字符。
  • 函数名第一个字母必须大写,单词与单词之间使用\color{blue}{函数名第一个字母必须大写,单词与单词之间使用}函数名第一个字母必须大写,单词与单词之间使用,下划线来分割。\color{red}{下划线来分割。}下划线来分割。
  • 全局函数必须以小写前缀"g"开头\color{blue}{全局函数必须以小写前缀"g"开头}全局函数必须以小写前缀"g"开头。
void g_Url_name ();
void Url_name ();

4、变量名:

  • 原则上,变量名的命名遵从匈牙利记法。即:前缀 + 类型 + 变量名(变量名称需要名词开头,不应该动词开头)
  1. 格式:

[m_|s_|g_] type [class name|struct name] variable name

  • 解释:

前缀

·m_ : 类的成员变量
·ms_:类的静态成员变量
·s_ :静态全局变量
·g_ :普通全局变量

类型缩写(type)

·char, TCHAR: ch
·char[],TCHAR[]: sz
·string: str
·bool, BOOL: b
·int, __int16,__int32,__int64: n
·long: l
·double: d
·float: f
·BYTE: by
·WORD: w
·DWORD: dw
·unsigned: u
·function: fn
·pointer :p
·long pointer :lp

  • 变量名最长不得超过20个字符。
int m_n_name = 0;//在.h文件中申明的变量
int _n_name = 0;//局部的变量

5、类名:

  • 必须以大写"C"开头,后面字母反映具体含义,以清晰表达类的用途和功能为原则。
  • 接口必须以大写"I"开头,代表 Interface 。
  • 当名称由多个单词构成时,每一个单词的第一个字母必须大写。
class IShape{public:virtual int __fastcall ifunc() = 0;
};// 派生类
class CUrlTable : public IShape
{}

6、结构体名、宏名、枚举名、联合名:

  • 全部大写。
  • 枚举名加小写前缀"enum"。例:
 typedef enum _CFILE_OPEN_MODE { enumOPEN_READONLY = 0, enumOPEN_READWRITE = 1, enumCREATE_ALWAY = 3 } CFILE_OPEN_MODE; //
  • 宏名加小写前缀"def"。 例:
 #define defMAXNUMBER 100
  • 结构名加小写前缀"tag",之后必须以大写"C"开头。例:
 typedef struct tagKPOINT {int x;int y; } KPOINT;
//·联合名加小写前缀"uni"。
typedef union _VARIANT{ char unichVal; int uninVal; long unilVal; float uniftVal;
} VARIANT;

C/C++源代码书写规范

  • 在.h/.cpp的开头应有一段格式统一的说明,内容包括:

a. 文件名 (FileName);
b. 简短说明文件功能、用途 (Comment);
c. 创建人 (Creater);
d.文件创建时间 (Date)。

例:


/*!*@file*@brief*@author*@date*/
  • 除非极其简单,否则对函数应有注释说明。内容包括:功能、入口/出口参数,必要时还可有备注或补充说明。

  • 每行代码的长度推荐为80列,最长不得超过120列;折行以对齐为准。

HANDLE CSOpenFile(
const char cszFileName[];
int nMode;
);//或者:BOOL CSReadFile(
HANDLE hFile;
void *pvBuffer;
int nReadSize;
int *pnReadSize;
);
  • 循环、分支代码,判断条件与执行代码不得在同一行上。
//正确:if (n == -2)n = 1;
elsen = 2;//不得写做:if (n == -2) n = 1;
else n = 2;
  • 指针的定义,* 号既可以紧接类型,也可以在变量名之前。
int* pnsize; //可写,最好不要int *pnsize; //可写int * pnsize; //不可写
  • 在类的成员函数内调用非成员函数时,在非成员函数名前必须加上“::”。

  • 函数入口参数有缺省值时,应注释说明。

BOOL KSSaveToFile(const char cszFileName[],BOOL bCanReplace /* = TRUE */);//或者:BOOL KSSaveToFile(const char cszFileName[],BOOL bCanReplace // = TRUE );
  • else if 必须写在一行。

  • 与‘{’、‘}’有关的各项规定:

    • ‘{’、‘}’应独占一行。在该行内可有注释。

      //正确:for (i = 0; i < cbLine; i++)
      { // .....printf("Line %d:", i);printf("%s\n", pFileLines);
      }
      //不得写做for (i = 0; i < cb; i++)
      {printf("Line %d:", i);
      printf("%s\n", pFileLines);}
      
    • ‘{’必须另起一行,‘{’之后的代码必须缩进一个Tab。‘{’与‘}’必须在同一列上。

      //正确:if (i > 0)
      {m = 1;n++;
      }
      //不得写做if (i > 0) {m = 1;
      n++;}
      //例外if (i == 0)
      { ASSERT(FALSE); return; }
      
    • 在循环、分支之后若只有一行代码,虽然可省略‘{’、‘}’,但不推荐这么做。若省略后可能引起歧义,则必须加上‘{’、‘}’。

  • 与空格有关的各项规定。

    • 在所有两目、三目运算符的两边都必须有空格。在单目运算符两端不必空格。但在‘->’、‘::’、‘.’、‘[’、‘]’等运算符前后,及‘&’(取地址)、‘*’(取值)等运算符之后不得有空格。

      //正确:int n = 0, nTemp;
      for (int i = nMinLine; i <= nMaxLine; i++)
      //不得写做int n=0, nTemp;
      for ( int i=nMinLine; i<=nMaxLine; i++ )
      
    • for、while、if 等关键词之后应有1个空格,再接‘(’,之后无空格;在结尾的‘)’前不得有空格。

      //正确if (-2 == n)//不得写做:if(-2 == n)//或if ( -2 == n )
      
    • 调用函数、宏时,‘(’、‘)’前后不得有空格。

      //正确:printf("%d\n", nIndex);//不得写做:printf ("%d\n", nIndex);printf( "%d\n", nIndex );
      
    • 类型强制转换时,‘(’‘)’前后不得有空格

      //可写做:(KSFile*)pFile;//也可写做:(KSFile *)pFile//不得写做:( KSFile* )pFile( KSFile * ) pFile
      
  • 与缩进有关的各项规定

    • 缩进以 Tab 为单位。1 个 Tab 为 4 个空格
    • 下列情况,代码缩进一个 Tab:
    1. 函数体相对函数名及‘{’、‘}’。

      int Power(int x)
      {return (x * x);
      }
      
    2. if、else、for、while、do 等之后的代码。
    3. 一行之内写不下,折行之后的代码,应在合理的位置进行折行。若有 + - * / 等运算符,则运算符应在上一行末尾,而不应在下一行的行首。
    • 下列情况,不必缩进:switch 之后的 case、default。

      switch (nID)
      {case ID_PLAY:......break;
      case ID_STOP:......break;
      default:......break;
      }
      

C++命名规则书写规范相关推荐

  1. Java/C/C++标识符命名规则和规范

    Java/C/C++标识符命名规则和规范 本篇文章是关于标识符的命名规则和命名规范的总结,有助于像作者本人一样的初学者或是知识模糊需要复习的小伙伴. 命名规则: (1).由26个英文字母大小写,数字0 ...

  2. python变量命名规则与规范(约定)

    引子 前些日子,大大的一位友友问了我一个问题,表示了对命名规范的不解.确实如此关于命名规范有一套相对严谨而复杂的理论,大大在此特就python的变量(以及函数和对象)命名规则与规范进行讲述. 规则 规 ...

  3. 变量的命名规则及规范

    变量的命名规则及规范 规则 可以包括数字.字母.下划线.$ 不能以数字开头 严格区分大小写 不能有空格 不能是关键字或保留字 规范 变量的名尽量有意义 遵循驼峰命名规则 a.大驼峰(UserName) ...

  4. 强力推荐的18种CSS命名和书写规范

    选择器的命名规范 1.模块化命名 例如: 与布局相关的样式以"g"为开头.如"g-content"和"g-header": 与挂钩相关的样式 ...

  5. JAVA标识符的命名规则和规范

    ps:规则和规范的区别,规则是必须遵守的,而规范不是强制遵守的,只是说按照规范来会更好. 1.标识符概念 (1)Java对各种变量.方法和类等命名时使用的字符序列称为标识符. (2)凡是自己可以起名字 ...

  6. mysql中对象标识符的命名规则,标准规范数据库命名规范.doc

    标准规范数据库命名规范 数据库命名规范 概述 基本原则 以大小写敏感编写SQL语句. 尽量使用Unicode 数据类型. 优先使用连接代替子查询或嵌套查询. 尽量使用参数化SQL查询代替语句拼接SQL ...

  7. java命名规则与规范

    标识符的使用 1.标识符:凡是自己可以起名字的地方都叫标识符. 比如:类名.变量名.方法名.接口名.包名- 2.标识符的命名规则: -->如果不遵守如下的规则,编译不通过!需要大家严格遵守 ①由 ...

  8. 一文轻松掌握python语言命名规则(规范)

    和C/C++.Java等语言一样,python在命名上也有一套约定俗成的规则,符合规范的命名可以让程序的可读性大大增加,从而使得代码的逻辑性增强,易于自己和其他协作者在以后的拓展中理解代码的意义,从而 ...

  9. 标志符的命名规则与规范

    关键字 : 在java程序中有特殊含义作用的单词, 所有字母全部小写. 保留字 : 从C++中保留下来的关键字, 在java中目前还不是关键字, 将来有可能是. 标识符 : 标识某个东西的符号, 简单 ...

最新文章

  1. OpenCV中的特征匹配(Feature Matching)
  2. 经典网络VGGNet介绍
  3. spring boot--最基础的hello world
  4. 自动编码(Autoencoder)器异常检测(outlier detection)实战
  5. 他给女朋友做了个树莓派复古相机,算法代码可自己编写,成本不到700元
  6. springboot mysql 事务_springBoot(14):使用SQL关系型数据库-事务处理
  7. Asp.Net Core Docker镜像更新系统从wheezy改为stretch
  8. dc/os_DC / OS中具有Java和数据库应用程序的服务发现
  9. K8s入门教程|这个给集群搞硬装的才是幕后英雄
  10. linux安装图像界面
  11. 如何在现代C ++中实现经典排序算法?
  12. 【转】用VC2008编译最新SVN版本OpenCV源代码
  13. oracle clob类型ibatis,Ibatis读写CLOB数据
  14. ts250服务器开启虚拟,ts250服务器恢复系统
  15. python处理word页码_word——插入页码
  16. 解决 Kotlin 换页符提示错误 Illegal escape f 无法使用问题
  17. 网站如何实现短信验证码功能?
  18. ArcGIS_栅格数据归一化
  19. 苹果自带相册打马赛克_剪映app怎么给视频局部打马赛克
  20. 开源消息总线eventBus学习

热门文章

  1. 阿里上线“娱乐宝”试水影视投资 大数据影视野心隐现
  2. kaggle比赛--Dog Breed Identification狗狗品种识别大赛
  3. python表情换头_用Python编写提取QQ表情的脚本
  4. 电位器(摇杆)和舵机组合应用
  5. 百变北京昌平龙脉温泉小鱼戏水2日自驾游(可延住)
  6. c语言产生随机数函数
  7. 新闻分类大赛赛题分析
  8. 初探机器学习之推荐系统的基础知识
  9. 女人对男人最有效的情话
  10. 小程序记录页面停留时间