编程规范Word文档格式.docx
- 文档编号:20899519
- 上传时间:2023-01-26
- 格式:DOCX
- 页数:34
- 大小:34.33KB
编程规范Word文档格式.docx
《编程规范Word文档格式.docx》由会员分享,可在线阅读,更多相关《编程规范Word文档格式.docx(34页珍藏版)》请在冰豆网上搜索。
!
~"
++"
--"
(地址运算符)等单目操作符前后不加空格
*pApple='
a'
;
//内容操作"
*"
与内容之间
flag=!
bIsEmpty;
//非操作"
p=&
cMem;
//地址操作"
与内容之间
i++;
//"
"
(4)"
->
."
前后不加空格
p->
id=pId;
指针前后不加空格
由于留空格所产生的清晰性是相对的,所以,在已经非常清晰的语句中没有必要再留空格,如最内层的括号内侧(即左括号后面和右括号前面)不要加空格,因为在C/C++语言中括号已经是最清晰的标志了。
另外,在长语句中,如果需要加的空格非常多,那么应该保持整体清晰,而在局部不加空格。
最后,即使留空格,也不要连续留两个以上空格(为了保证缩进和排比留空除外)。
规则3>
函数体的开始,类的定义,结构的定义,if、for、do、while、switch及case语句中的程序都应采用缩进方式,独占一行并且位于同一列,同时与引用它们的语句左对齐
例如下例不符合规范。
for(...){
...//程序代码
}
if(...)
{
voidDoExam(void)
应如下书写。
for(...)
规则4>
功能相对独立的程序块之间或for、if、do、while、switch等语句前后应加一空行。
例如以下例子不符合规范。
例一:
if(!
ValidNi(ni))
nRepssnInd=SsnData[index].nRepssnIndex;
nRepssnNi
=SsnData[index].ni;
例二:
char*pContext;
int
nIndex;
longlCounter;
pContext=new(CString);
if(pContext==NULL)
returnFALSE;
应如下书写
规则5>
if、while、for、case、default、do等语句自占一行。
示例:
如下例子不符合规范。
if(pUserCR==NULL)return;
应如下书写:
if(pUserCR==NULL)
return;
规则6>
若语句较长(多于80字符),可分成多行写,划分出的新行要进行适应的缩进,使排版整齐,语句可读。
memset(pData->
pData+pData->
nCount,0,
(m_nMax-pData->
nCount)*sizeof(LPVOID));
CNoTrackObject*pValue=
(CNoTrackObject*)_afxThreadData->
GetThreadValue(m_nSlot);
for(i=0,j=0;
(i<
BufferKeyword[WordIndex].nWordLength)
(j<
NewKeyword.nWordLength);
i++,j++)
...
//程序代码
规则7>
一行最多写一条语句。
rect.length=0;
rect.width=0;
rect.length=width=0;
都应书写成:
rect.width
=0;
规则8>
对结构成员赋值,等号对齐。
rect.top
=0;
rect.left
=0;
rect.right
=300;
rect.bottom
=200;
规则9>
#define的各个字段对齐。
以下示例不符合规范
#define
MAX_TASK_NUMBER100
LEFT_X
10
BOTTOM_Y
400
应书写成:
MAX_TASK_NUMBER
100
400
规则10>
不同类型的操作符混合使用时,使用括号给出优先级。
如本来是正确的代码:
if(year%4==0||year%100!
=0&
year%400==0)
如果加上括号,则更清晰。
if((year%4)==0||((year%100)!
(year%400)==0))
2.2.
可理解性
2.2.1.注释
注释的原则是有助于对程序的阅读理解,注释不宜太多也不能太少,太少不利于代码理解,太多则会对阅读产生干扰,因此只在必要的地方才加注释,而且注释要准确、易懂、尽可能简洁。
注释量一般控制在30%到50%之间。
规则1>
程序在必要的地方必须有注释,注释要准确、易懂、简洁。
例如如下注释意义不大。
/*如果bReceiveFlag为TRUE*/
if(bReceiveFlag==TRUE)
而如下的注释则给出了额外有用的信息。
/*如果mtp从连接处获得一个消息*/
if(bReceiveFlag==TURE)
注释应与其描述的代码相近,对代码的注释应放在其上方或右方(对单条语句的注释)相邻位置,不可放在下面,如放于上方则需与其上面的代码用空行隔开。
例子1
/*获得系统指针和网络指针的副本*/
例子2
/*获得系统指针和网络指针的副本*/
对于所有的常量,变量,数据结构声明(包括数组、结构、类、枚举等),如果其命名不是充分自注释的,在声明时都必须加以注释,说明其含义。
/*活动任务的数量*/
MAX_ACT_TASK_NUMBER
1000
/*带原始用户信息的SCCP接口*/
enum
SCCP_USER_PRIMITIVE
N_UNITDATA_IND,
/*向SCCP用户报告单元数据已经到达
*/
N_UNITDATA_REQ,
/*SCCP用户的单元数据发送请求
};
头文件、源文件的头部,应进行注释。
注释必须列出:
文件名、作者、目的、功能、修改日志等。
/*********************************************
文件名:
编写者:
编写日期:
简要描述:
修改记录:
********************************************/
说明:
每条修改记录应包括修改日期、修改者及修改内容简述。
函数头部应进行注释,列出:
函数的目的、功能、输入参数、输出参数、修改日志等。
形式如下:
/*************************************************
函数名称:
//函数目的、功能等的描述
输入:
//输入参数说明,包括每个参数的作用、取值说明及参数间关系,
输出:
//输出参数的说明,返回值的说明
修改日志:
*************************************************/
对一些复杂的函数,在注释中最好提供典型用法。
仔细定义并明确公共变量的含义、作用、取值范围及使用方法。
在对变量声明的同时,应对其含义、作用、取值范围及使用方法进行注释说明,同时若有必要还应说明与其它变量的关系。
明确公共变量与操作此公共变量的函数或过程的关系,如访问、修改及创建等。
/*
SCCP转换时错误代码*/
全局错误代码,含义如下
*/
//变量作用、含义
0-成功
1-GT表错误
2-GT错误
其它值-未使用
//变量取值范围
对指针进行充分的注释说明,对其作用、含义、使用范围、注意事项等说明清楚。
在对指针变量、特别是比较复杂的指针变量声明时,应对其含义、作用及使用范围进行注释说明,如有必要,还应说明其使用方法、注意事项等。
/*学生记录列表的头指针*/
当在此模块中创建该列表时,该头指针必须初始化,*/
这样可以利用GetListHead()获得这一列表。
//指针作用、含义
该指针只在本模块使用,其它模块通过调用GetListHead()获取*/
当使用时必须保证它非空
//使用范围、方法
STUDENT_RECORD
*pStudentRecHead;
对重要代码段的功能、意图进行注释,提供有用的、额外的信息。
并在该代码段的结束处加一行注释表示该段代码结束。
/*可选通道的组合*/
if((gsmBCIe31->
radioChReq>
=DUAL_HR_RCR)
&
(gsmBCIe32->
=DUAL_HR_RCR))
gsmBCIe31->
radioChReq=FR_RCR;
gsmBCIe32->
elseif((gsmBCIe31->
radioChReq==FR_RCR))
radioChReq==FR_RCR)
/*本块结束(可选通道组合)
在switch语句中,对没有break语句的case分支加上注释说明。
switch(SubT30State)
caseTA0:
AT(CHANNEL,"
AT+FCLASS=1\r"
0);
if(T30Status!
=0)
{
return
(1);
}
InitFax();
/*准备发送传真*/
ATD\r"
-1);
/*发送CNG,接收CED和HDLC标志*/
T1_Flg=1;
iResCode=0;
/*没有break;
*/
caseTA1:
iResCode=GetModemMsg(CHANNEL);
break;
default:
规则10>
维护代码时,要更新相应的注释,删除不再有用的注释。
保持代码、注释的一致性,避免产生误解。
2.2命名
本文列出VisualC++的标识符命名规范。
标识符缩写
形成缩写的几种技术:
1)
去掉所有的不在词头的元音字母。
如screen写成scrn,primtive写成prmv。
2)
使用每个单词的头一个或几个字母。
如ChannelActivation写成ChanActiv,ReleaseIndication写成RelInd。
3)
使用变量名中每个有典型意义的单词。
如CountofFailure写成FailCnt。
4)
去掉无用的单词后缀ing,ed等。
如PagingRequest写成PagReq。
5)
使用标准的或惯用的缩写形式(包括协议文件中出现的缩写形式)。
如BSIC(BaseStationIdentificationCode)、MAP(MobileApplicationPart)。
关于缩写的准则:
缩写应该保持一致性。
如Channel不要有时缩写成Chan,有时缩写成Ch。
Length有时缩写成Len,有时缩写成len。
在源代码头部加入注解来说明协议相关的、非通用缩写。
标识符的长度不超过32个字符。
变量命名约定参照匈牙利记法,即
[作用范围域前缀]+[前缀]+基本类型+变量名
其中:
前缀是可选项,以小写字母表示;
基本类型是必选项,以小写字母表示;
变量名是必选项,可多个单词(或缩写)合在一起,每个单词首字母大写。
前缀列表如下:
前缀
意义
举例
g_
Global
全局变量
g_MyVar
m_
类成员变量模块级变量
m_ListBox,m_Size
s_
static
静态变量
s_Count
h
Handle
句柄
hWnd
p
Pointer
指针
pTheWord
lp
LongPoint
长指针
lpCmd
a
Array数组
aErr
基本类型列表如下:
基本类型
b
Boolean
bIsOK
by
Byte
byNum
c
Char
cMyChar
i或n
Intger
nTestNumber
u
Unsignedinteger
uCount
ul
UnsignedLong
ulTime
w
WordwPara
dw
DoubleWord
dwPara
l
Long
lPara
f
FloatfTotal
s
StringsTemp
sz
结束的字符串
szTrees
fn
Funtion
fnAdd
enm
枚举型
enmDays
x,y
x,y坐标
宏和常量的命名。
宏和常量的命名规则:
单词的字母全部大写,各单词之间用下划线隔开。
命名举例:
MAX_SLOT_NUM
8
EI_ENCR_INFO
0x07
constintMAX_ARRAY
结构和结构成员的命名。
结构名各单词的字母均为大写,单词间用下划线连接。
可用或不用typedef,但是要保持一致,不能有的结构用typedef,有的又不用。
如:
typedefstructLOCAL_SPC_TABLE_STRU
char
cValid;
nSpcCode[MAX_NET_NUM];
}LOCAL_SPC_TABLE;
结构成员的命名同变量的命名规则。
枚举和枚举成员的命名。
枚举名各单词的字母均为大写,单词间用下划线隔开。
枚举成员的命名规则:
单词的字母全部大写,各单词之间用下划线隔开;
要求各成员的第一个单词相同。
typdefenum
LAPD_MDL_ASSIGN_REQ,
LAPD_MDL_ASSIGN_IND,
LAPD_DL_DATA_REQ,
LAPD_DL_DATA_IND,
LAPD_DL_UNIT_DATA_REQ,
LAPD_DL_UNIT_DATA_IND,
}LAPD_PRMV_TYPE;
类的命名
C
类
CMyClass
CO
COM
COMMyObjectClass
CF
COMclassfactory
CFMyClassFactory
I
COMinterfaceclass
IMyInterface
CImpl
COMimplementationclass
CImplMyInterface
函数的命名
单词首字母为大写,其余均为小写,单词之间不用下划线。
函数名应以一个动词开头。
voidPerformSelfTest(void);
voidProcChanAct(MSG_CHAN_ACTIV*pMsg,UCMsgLen);
2.3.
可维护性
在逻辑表达式中使用明确的逻辑判断。
如下逻辑表达式不规范。
if(strlen(strName))
for(index=MAX_SSN_NUMBER;
index;
index--)
while(p&
*p)
//假设p为字符指针
应改为如下:
if(strlen(strName)!
=0)
index!
while((p!
=NULL)&
(*p!
='
\0'
))
预编译条件不应分离一完整的语句。
不正确:
if((cond==GLRUN)
#ifdefDEBUG
||(cond==GLWAIT)
#endif
)
正确:
if(cond==GLRUN||cond==GLWAIT)
#else
if(cond==GLRUN)
在宏定义中合并预编译条件。
#ifdef
EXPORT
for(i=0;
i<
MAX_MSXRSM;
i++)
for(i=0;
MAX_MSRSM;
头文件中:
#defineMAX_MS_RSM
MA
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 编程 规范