一些函数、变量命名法及代码规范

驼峰命名法

骆驼式命名法(Camel-Case)又称驼峰式命名法,也称小驼峰式命名法。

骆驼式命名法就是当变量名或函数名是由一个或多个单词连结在一起时,第一个单词以小写字母开始;从第二个单词开始以后的每个单词的首字母都采用大写字母。

例如:myFirstName、myLastName,这样的变量名看上去就像骆驼峰一样此起彼伏,故得名。

匈牙利命名法

据说这种命名法是一位叫 Charles Simonyi 的匈牙利程序员发明的,后来他在微软待了几年,于是这种命名法就通过微软的各种产品和文档资料向世界传播开了。 匈牙利命名法的基本原则是:变量名=属性+类型+对象描述 。

例子:

pfnEatApple :pfn 是类型描述,表示指向函数的指针, EatApple 是变量对象描述,所以它表示指向 EatApple 函数的函数指针变量。

hwnd :h 是类型描述,表示句柄, wnd 是变量对象描述,表示窗口,所以 hwnd 表示窗口句柄;

g_cch :g_ 是属性描述,表示全局变量,c 和 ch 分别是计数类型和字符类型,一起表示变量类型,这里忽略了对象描述,所以它表示一个对字符进行计数的全局变量。

(1)属性部分

g_ 全局变量
c_ 常量
m_ c++类成员变量
s_ 静态变量

(2)类型部分:

数组 a
指针 p
函数 fn
无效 v
句柄 h
长整型 l
布尔 b
浮点型(有时也指文件) f
双字  dw
字符串  sz
短整型  n
双精度浮点 d
计数 c(通常用cnt)
字符 ch(通常用c)
整型 i(通常用n)
字节 by
字 w
实型 r
无符号 u

(3)描述部分

最大 Max
最小 Min
初始化 Init
临时变量 T(或Temp)
源对象 Src
目的对象 Dest

帕斯卡命名法

帕斯卡命名法指当变量名和函式名称是由二个或二个以上单词连结在一起,每个单词首字母大写。

单字之间不以空格断开或连接号(-)、底线(_)连结,第一个单词首字母采用大写字母;后续单词的首字母亦用大写字母,例如:FirstName、LastName。 也有人称之为大驼峰式命名法(Upper Camel Case)

下划线命名法

下划线命名法变量名和函式名称是由二个或二个以上单词连结在一起,每个单词用下划线隔开并且单词都是小写。

例如:print_employee。下划线命名法是随着C语言的出现流行起来的,在UNIX/LIUNX这样的环境,以及GNU代码中使用非常普遍。

一些代码规范

以下来源:《安富莱教程文档》

1、文件与目录

(1)文件的命名

文件的命名要准确清晰地表达其内容,同时文件名应该精练,防止文件名过长而造成使用不便。在文件名中可以适当地使用缩写。以下提供两种命名方式以供参考:

  • 各程序模块的文件命名开头 2 个消协字母代表本模块的功能:

如:主控程序为 mpMain.cmpDisp.c 等。

  • 不写模块功能标识:

如:主控程序为 Main.cDisp.c 等。

(2)头文件中段落安排顺序

// 1、文件头注释
// 2、防止重复引用头文件的设置
// 3、#include 部分
// 4、enum 常量声明
// 5、类型声明和定义,包括 struct、union、typedef 等
// 6、全局变量声明
// 7、文件级变量声明
// 8、全局或文件级函数声明
// 9、函数实现。按函数声明的顺序排列
// 10、文件尾注释

(3)在引用头文件时,不要使用绝对路径

如果使用绝对路径,当需要移动目录时,必须修改所有相关代码,繁琐且不安全;使用相对路径,当需要移动目录时,只需修改编译器的某个选项即可。例如:

#include “/project/inc/hello.h” /* 不应使用绝对路径 */
#include “../inc/hello.h”            /* 可以使用相对路径 */

(4)在引用头文件时 ,使用<>还是""        

#include <stdio.h>          /* 标准头文件 */
#include <projdefs.h>     /* 工程制定目录头文件 */
#include “global.h”         /* 当前目录头文件 */
#include “inc/config.h” /* 路径相对于当前目录的头文件 */

(5)防止头文件被重复引用

#ifndef __DISP_H /* 文件名前名加两个下划线“__”,后面加 “_H”
#define __DISP_H
...
...
#endif

(6)头文件中只存放“声明”而不存放“定义”

(7)文件的长度

文件的长度没有非常严格的要求,但应尽量避免文件过长。一般来说,文件长度应尽量保持在 1000 行之内 。

2、排版

(1)程序块要采用缩进风格编写,缩进的空格数为 4 个。

(2)相对独立的程序块之间、变量说明之后必须加空行 。

(3) 较长的语句或函数过程参数(>80 字符)要分成多行书写,长表达式要在低优先级操作符处划分新行,操作符放在新行之首,划分出的新行要进行适当的缩进,使排版整齐,语句可读。

(4) 不允许把多个短语句写在一行中,即一行只写一条语句

(5)程序块的分界符(如大括号‘{’和‘}’ )应各独占一行并且位于同一列

(6) 在两个以上的关键字、变量、常量进行对等操作时,它们之间的操作符之前、之后或者前后要加空格;进行非对等操作时,如果是关系密切的立即操作符(如->),后不应加空格。

示例:

  • 逗号、分号只在后面加空格。


  • 比较操作符,赋值操作符"="、 "+=",算术操作符"+"、"%",逻辑操作符"&&"、"&",位域操作符"<<"、"^"等双目操作符的前后加空格。


  • "!"、"~"、"++"、"--"、"&"(地址运算符)等单目操作符前后不加空格。


  • "->"、"."前后不加空格。


  • if、for、while、switch 等与后面的括号间应加空格,使 if 等关键字更为突出、明显,函数名与其后的括号之间不加空格,以与保留字区别开。

3、注释

(1) 一般的,源程序有效注释量必须在 20%以上。

说明:注释的原则是有助于对程序的阅读理解,在该加的地方都加,注释不宜太多也不能太少,注释语言必须准确、易懂、简洁 。

(2) 在文件的开始部分,应该给出关于文件版权、内容简介、修改历史等项目的说明。

在创建代码和每次更新代码时,都必须在文件的历史记录中标注版本号、日期、作者、更改说明等项目。下面是一个范例,当然,并不局限于此格式,但上述信息建议要包含在内。

(3)对于函数,在函数实现之前,应该给出和函数的实现相关的足够而精练的注释信息。

示例:

下面这段函数的注释比较标准,当然,并不局限于此格式,但上述信息建议要包含在内。

(4) 边写代码边注释,修改代码同时修改相应的注释,以保证注释与代码的一致性。不再有用的注释要删除。

(5) 注释的内容要清楚、明了,含义准确,防止注释二义性。

说明:错误的注释不但无益反而有害。注释主要阐述代码做了什么(What),或者如果有必要的话,阐述为什么要这么做(Why),注释并不是用来阐述它究竟是如何实现算法(How)的。

(6) 避免在注释中使用缩写,特别是非常用缩写。

说明:在使用缩写时或之前,应对缩写进行必要的说明。

(7) 注释应与其描述的代码靠近,对代码的注释应放在其上方或右方(对单条语句的注释)相邻位置, 不可放在下面,如放于上方则需与其上面的代码用空行隔开。

示例:如下例子不符合规范。

例 1:不规范的写法

例 2:不规范的写法

例 3:规范的写法


例 4:不规范的写法,显得代码过于紧凑

例 5:规范的写法

(8) 注释与所描述内容进行同样的缩排。

说明:可使程序排版整齐,并方便注释的阅读与理解。
例 1:如下例子,排版不整齐,阅读稍感不方便。

例 2:正确的布局。

(9) 对变量的定义和分支语句(条件分支、循环语句等)必须编写注释。

说明:这些语句往往是程序实现某一特定功能的关键,对于维护人员来说,良好的注释帮助更好的理解程序,有时甚至优于看设计文档。

(10) 对于 switch 语句下的 case 语句,如果因为特殊情况需要处理完一个 case 后进入下一个 case 处理,必须在该 case 语句处理完、下一个 case 语句前加上明确的注释。

说明:这样比较清楚程序编写者的意图,有效防止无故遗漏 break 语句。

示例(注意斜体加粗部分):

(11) 注释格式尽量统一,建议使用“/* …… */”,因为 C++注释“//”并不被所有 C 编译器支持。

(12) 注释应考虑程序易读及外观排版的因素,使用的语言若是中、英兼有的,建议多使用中文,除非能非常流利准确的用英文表达。

说明:注释语言不统一,影响程序易读性和外观排版,出于对维护人员的考虑,建议使用中文。

(13) 标识符的命名要清晰、明了,有明确含义,同时使用完整的单词或大家基本可以理解的缩写,避 免使人产生误解。

说明:较短的单词可通过去掉“元音”形成缩写;较长的单词可取单词的头几个字母形成缩写;一些单词有大家公认的缩写。
示例:如下单词的缩写能够被大家基本认可。

temp 可缩写为 tmp;
flag 可缩写为 flg;
statistic 可缩写为 stat;
increment 可缩写为 inc;
message 可缩写为 msg;

(14) 命名中若使用特殊约定或缩写,则要有注释说明。
说明:应该在源文件的开始之处,对文件中所使用的缩写或约定,特别是特殊的缩写,进行必要的注释说明。

(15) 自己特有的命名风格,要自始至终保持一致,不可来回变化。
说明:个人的命名风格,在符合所在项目组或产品组的命名规则的前提下,才可使用。(即命名规则中没有规定到的地方才可有个人命名风格)

(16) 对于变量命名,禁止取单个字符(如 i、j、k…)

建议除了要有具体含义外,还能表明其变量类型、数据类型等,但 i、j、k 作局部循环变量是允许的。变量,尤其是局部变量,如果用单个字符表示,很容易敲错(如i写成j),而编译时又检查不出来,有可能为了这个小小的错误而花费大量的查错时间 。

(17) 命名规范必须与所使用的系统风格保持一致,并在同一项目中统一

比如采用 UNIX 的全小写加下划线的风格或大小写混排的方式,不要使用大小写与下划线混排的方式,用作特殊标识如标识成员变量或全局变量的 m_和 g_,其后加上大小写混排的方式是允许的。
示例:Add_User不允许,add_user、AddUser、m_AddUser允许。

(18) 除非必要,不要用数字或较奇怪的字符来定义标识符。
示例:如下命名,使人产生疑惑。

应改为有意义的单词命名:

4、可读性

(1) 注意运算符的优先级,并用括号明确表达式的操作顺序,避免使用默认优先级。

(2) 避免使用不易理解的数字,用有意义的标识来替代。

示例:如下的程序可读性差

应改为如下形式 :

(3) 不要使用难懂的技巧性很高的语句,除非很有必要时。

说明:高技巧语句不等于高效率的程序,实际上程序的效率关键在于算法。
示例:如下表达式,考虑不周就可能出问题,也较难理解。

应分别改为如下:

5、变量、 结构、 常量、 宏

(1) 为了方便书写及记忆,变量类型采用如下重定义:

(2) 常见类型的前缀

  • 对于一些常见类型的变量,应在其名字前标注表示其类型的前缀。前缀用小写字母表示。前缀的使用请参照下列表格中说明。

(3) 变量作用域的前缀

为了清晰的标识变量的作用域,减少发生命名冲突,应该在变量类型前缀之前再加上表示变量作用域的前缀,并在变量类型前缀和变量作用域前缀之间用下划线 - 隔开。

具体的规则如下:

  • 对于全局变量(global variable),在其名称前加g和变量类型符号前缀。

  uint32_t g_ulParaWord;uint8_t g_ucByte;
  • 对于静态变量(static variable),在其名称前加s和变量类型符号前缀。

  static uint32_t s_ulParaWord;static uint8_t s_ucByte;
  • 函数内部等局部变量前不加作用域前缀。

  • 对于常量,当可能发生作用域和名字冲突问题时,以上几条规则对于常量同样适用。注意,虽然常量名的核心部分全部大写,但此时常量的前缀仍然用小写字母,以保持前缀的一致性。

(4) 结构体命名规则

表示类型的名字,所有名字以小写字母tag开头,之后每个英文单词的第一个字母大写(包括第一个单词的第一个字母),其他字母小写,结尾_T 标识。单词之间不使用下划线分隔,结构体变量以 t 开头。如:

/* 结构体命名类型名 */
typedef struct tagBillQuery_T
{
...
}BillQuery_T;
/* 结构体变量定义 */
BillQuery_T tBillQuery;

(5)对于枚举定义全部采用大写,结尾_E 标识。

(6)常量、宏、模版的名字应该全部大写。如果这些名字由多个单词组成,则单词之间用下划线分隔。

#define LOG_BUF_SIZE 8000

6、函数

(1) 函数的命名规则。

每一个函数名前缀需包含模块名,模块名为小写,与函数名区别开。

如:uartReceive(串口接收)

备注:对于非常简单的程序,可以不加模块名。

(2)函数的形参。

函数的的形参都以下划线_开头,已示与普通变量进行区分,对于没有形参为空的函数(void)括号紧跟函数后面。

uint32_t uartConvUartBaud(uint32_t _ulBaud){}

(3) 一个函数仅完成一件功能。

(4) 函数名应准确描述函数的功能,使用动宾词组为执行某操作的函数命名。

说明:避免用含义不清的动词如processhandle等为函数命名,因为这些动词并没有说明要具体做什么。

示例:参照如下方式命名函数。

(5)避免设计五个以上参数函数,不使用的参数从接口中去掉。

说明:目的减少函数间接口的复杂度,复杂的参数可以使用结构传递。

(6)在调用函数填写参数时,应尽量减少没有必要的默认数据类型转换或强制数据类型转换。
说明:因为数据类型转换或多或少存在危险。

(7) 防止把没有关联的语句放到一个函数中。

示例:如下函数就是一种随机内聚。

矩形的长、宽与点的坐标基本没有任何关系,故以上函数是随机内聚。应如下分为两个函数:


扫码或长按关注

回复「 篮球的大肚子」进入技术群聊

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/468040.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

linux 信号_[入门]谈一谈Linux中的信号

也许有一些同学有这样的疑问&#xff1a;kill -9 PID 中的 -9 到底是什么意思&#xff1f;Ctrl C 是为什么可以停止掉运行的程序&#xff1f;1. 什么是信号&#xff1f;在计算机科学中&#xff0c;信号是Unix、类Unix以及其他POSIX兼容的操作系统中进程间通讯的一种有限制的方…

终于讲透了,史上最详细的RS485串口通讯!

RS485接口组成的半双工网络&#xff0c;一般是两线制&#xff0c;多采用屏蔽双绞线传输&#xff0c;这种接线方式为总线式拓扑结构在同一总线上最多可以挂接32个结点。我们知道&#xff0c;最初数据是模拟信号输出简单过程量&#xff0c;后来仪表接口是RS232接口&#xff0c;这…

react 组件封装原则_我理解的React:React 到底是什么?

希望本文能帮助没接触过 React 的同学&#xff0c;对React有个大致的理解。最近要做一个“前端零基础的入门课程分享”&#xff0c;很多非前端同学可能只是知道 React 是个前端框架&#xff0c;整体对 React 的理解还是很模糊&#xff0c;借此机会&#xff0c;分享一下我对 Rea…

解引用NULL为什么会导致程序挂死?

来源&#xff1a;公众号【编程珠玑】作者&#xff1a;守望先生ID&#xff1a;shouwangxiansheng解引用NULL指针为什么会出错&#xff0c;导致程序挂死&#xff1f;或者说访问内存地址为0的位置为什么会视为非法&#xff1f;先了解NULL参考《NULL,0,\0有何区别&#xff1f;》。解…

关于主机的思维导图_送给孩子最好的思维导图课程

思维导图寒假班来了1关于思维导图思维导图是一种简单而有效的图形思维工具&#xff0c;主要元素包含图形、线条、关键字、颜色&#xff0c;配合下图&#xff0c;我们能理解思维导图利用了左脑和右脑的工作机理&#xff0c;能够充分调动大脑的分析推理和想象创新能力&#xff0c…

那年夏日我吃瓜

好吧&#xff0c;标题就是为了吸引读者进来增加阅读量的&#xff0c;作为一个公众号小编&#xff0c;我没有什么大量的墨水贡献给大家&#xff0c;但是就是想吹牛逼一下。我最近很懒&#xff0c;都有好几天没有更新新的文章了&#xff0c;然后大家也看到我自己写的东西没有什么…

未来计算机是否有意识或者人为的赋予意识,人工智能会有自我意识吗?

在西雅图的艾伦脑科学研究所&#xff0c;正在进行大规模的研究&#xff0c;以了解人脑中860亿个神经元是如何连接的。目的是产生所有连接的图&#xff1a;连接组。该研究所的科学家现在正在重建一立方毫米的老鼠大脑&#xff0c;这是有史以来最复杂的。绘制出大脑连接方式的映射…

别瞎找了,你要的C语言经典示例都在这~

大家周末好&#xff0c;这篇文章是从朋友的号那边看到的&#xff0c;确实不错&#xff0c;如果C语言还觉得没有胸有成熟的话&#xff0c;可以看看。里面的例子都很经典&#xff0c;有条件的同学实际操作一下。给大家找了一些C语言经典示例&#xff0c;github链接&#xff1a;ht…

广联达文件被锁怎么修复_事无巨细的绕过Apple id教程+修复蜂窝数据/电话

本次教程首发于Apple tech752大神&#xff0c;十分感谢他的nice job&#xff01;通过这份教程你可以绕过Apple id激活锁&#xff0c;并且保留通话和移动数据和短信的功能&#xff0c;解决了由于基带锁导致绕过ID的机器不可以打电话的问题。写在前面&#xff1a;1.请勿用于捡到/…

计算机辅助翻译专业院校,2017年北大计算机辅助翻译考研经验分享

2017年北大计算机辅助翻译考研经验分享【摘要】笔者完美地将自身优势与兴趣相结合&#xff0c;最终成功折桂北大计算机辅助翻译。►择校(兴趣优势)其实我最开始考研的目标并不是北大的计算机作者hhhhhh1111次阅读2017-07-06【摘要】笔者完美地将自身优势与兴趣相结合&#xff0…

如何写出让同事无法维护的代码?

译文&#xff1a;http://coolshell.cn/articles/4758.html原文&#xff1a;http://mindprod.com/jgloss/unmain.html文章转自公众号 strongerHuang对&#xff0c;你没看错&#xff0c;本文就是教你怎么写出让同事无法维护的代码&#xff0c;因为只有这样&#xff0c;别人才不能…

调试,是一件有挑战的事情

如果你不是工程师&#xff0c;你应该享受不到加班调试的乐趣吧&#xff0c;我记得在大学的时候&#xff0c;我第一次调试I2C时序&#xff0c;当时用的芯片是24C02的RTC芯片&#xff0c;用51单片机模拟I2C时序&#xff0c;怎么整也整不出来&#xff0c;时序这个东西&#xff0c;…

make 命令_make考点总结(建议中、高考学生收藏)

考点一、“make宾语宾语补足语”结构1、这个结构表示“ 使…… 处于某种状态”“ 使……怎么样”。其中宾语的补足语&#xff0c;通常是表示情感的词(happy, sad)或者是表示状态的词(rich, strong, ill)。比如&#xff0c;Make your room clean.“使你的房间干净”&#xff0c;…

如何通俗易懂的解释PWM?

学过电力电子的小伙伴们都知道…交流电“整流”为直流电&#xff08;a&#xff09;…直流电“逆变”为交流电&#xff08;b&#xff09;…交流电“变压”为交流电&#xff08;c&#xff09;…直流电“斩波”为直流电&#xff08;d&#xff09;…“变压”&#xff08;c&#xff…

一个前辈总结的思考

文章是一个互联网的前辈写的&#xff0c;但是我觉得技术应该不分什么互联网不互联网&#xff0c;里面说到的一些内容&#xff0c;值得我们借鉴&#xff0c;分享给大家&#xff0c;希望大家能有一些认知上的收获&#xff0c;比较接地气&#xff0c;内容中讲到送外卖的部分也是真…

东南大学计算机学院张敏灵,东南大学张敏灵教授来我校作学术报告

10月24日下午&#xff0c;在南校区怀德楼B410会议室&#xff0c;东南大学计算机科学与工程学院张敏灵教授作题为“偏标记学习的研究”学术报告。报告由信息工程学院院长陈荣主持&#xff0c;信息学院师生聆听报告。张敏灵教授介绍了偏标记学习及相关研究工作的展开。偏标记学习…

我准备毕业了,怎么规划我的职业生涯?

昨天&#xff0c;微信上收到一个读者的留言&#xff0c;想咨询一下职业规划&#xff0c;碰巧的是&#xff0c;他非常喜欢驱动相关的工作&#xff0c;刚好碰巧的是&#xff0c;我有这方面的经验&#xff0c;所以很耐心的解答了下&#xff0c;发出来给更多的人看看&#xff0c;希…

计算机音乐奔跑,跑起来!100首最适合跑步的音乐

原标题&#xff1a;跑起来&#xff01;100首最适合跑步的音乐喜爱跑步、健身的人&#xff0c;都喜欢一边听音乐一边运动&#xff0c;而且会比没有音乐时燃烧脂肪速度要快&#xff0c;提高新陈代谢的能力&#xff01;小乐君今天给大家盘点100首全球最受欢迎的跑步音乐&#xff0…

危难时刻,每个人都应该站出来

转发一条同济医院发的我来给大家减轻一下恐慌。说实话目前这个肺炎传染性的确很强&#xff0c;但是重症发生率并不高&#xff0c;多出现在有基础疾病身体状况不好的老年人。一般患者就是自行隔离休息是最好的处理方式&#xff0c;一周也就恢复但是隔离需要14天&#xff0c;隔离…

Maven整合Spring3.0+Mybatis3.2+Struts2.3+查找坐标+jar包依赖(五)

依赖传递 只添加了一个struts2-core依赖&#xff0c;发现项目中出现了很多jar&#xff0c;这种情况 叫 依赖传递 查找坐标 依赖版本冲突的解决 1、 第一声明优先原则 <dependencies><!-- spring-beans-4.2.4 --><dependency><groupId>org.springfra…