1. 基本要求
1.1 程序結(jié)構(gòu)清析,簡單易懂,單個(gè)函數(shù)的程序行數(shù)不得超過100行。
1.2 打算干什么,要簡單,直接了當(dāng),代碼精簡,避免垃圾程序。
1.3 盡量使用標(biāo)準(zhǔn)庫函數(shù)和公共函數(shù)。
1.4 不要隨意定義全局變量,盡量使用局部變量。
1.5 使用括號(hào)以避免二義性。
2.可讀性要求
2.1 可讀性第一,效率第二。
2.2 保持注釋與代碼完全一致。
2.3 每個(gè)源程序文件,都有文件頭說明,說明規(guī)格見規(guī)范。
2.4 每個(gè)函數(shù),都有函數(shù)頭說明,說明規(guī)格見規(guī)范。
2.5 主要變量(結(jié)構(gòu)、聯(lián)合、類或?qū)ο螅┒x或引用時(shí),注釋能反映其含義。
2.7 常量定義(DEFINE)有相應(yīng)說明。
2.8 處理過程的每個(gè)階段都有相關(guān)注釋說明。
2.9 在典型算法前都有注釋。
2.10 利用縮進(jìn)來顯示程序的邏輯結(jié)構(gòu),縮進(jìn)量一致并以Tab鍵為單位,定義Tab為 6個(gè)
字節(jié)。
2.11 循環(huán)、分支層次不要超過五層。
2.12 注釋可以與語句在同一行,也可以在上行。
2.13 空行和空白字符也是一種特殊注釋。
2.14 一目了然的語句不加注釋。
2.15 注釋的作用范圍可以為:定義、引用、條件分支以及一段代碼。
2.16 注釋行數(shù)(不包括程序頭和函數(shù)頭說明部份)應(yīng)占總行數(shù)的 1/5 到 1/3 。
3. 結(jié)構(gòu)化要求
3.1 禁止出現(xiàn)兩條等價(jià)的支路。
3.2 禁止GOTO語句。
3.3 用 IF 語句來強(qiáng)調(diào)只執(zhí)行兩組語句中的一組。禁止 ELSE GOTO 和 ELSE RETURN。
3.4 用 CASE 實(shí)現(xiàn)多路分支。
3.5 避免從循環(huán)引出多個(gè)出口。
3.6 函數(shù)只有一個(gè)出口。
3.7 不使用條件賦值語句。
3.8 避免不必要的分支。
3.9 不要輕易用條件分支去替換邏輯表達(dá)式。
4. 正確性與容錯(cuò)性要求
4.1 程序首先是正確,其次是優(yōu)美
4.2 無法證明你的程序沒有錯(cuò)誤,因此在編寫完一段程序后,應(yīng)先回頭檢查。
4.3 改一個(gè)錯(cuò)誤時(shí)可能產(chǎn)生新的錯(cuò)誤,因此在修改前首先考慮對(duì)其它程序的影響。
4.4 所有變量在調(diào)用前必須被初始化。
4.5 對(duì)所有的用戶輸入,必須進(jìn)行合法性檢查。
4.6 不要比較浮點(diǎn)數(shù)的相等,
如: 10.0 * 0.1 == 1.0 , 不可靠
4.7 程序與環(huán)境或狀態(tài)發(fā)生關(guān)系時(shí),必須主動(dòng)去處理發(fā)生的意外事件,如文件能否
邏輯鎖定、打印機(jī)是否聯(lián)機(jī)等。
4.8 單元測試也是編程的一部份,提交聯(lián)調(diào)測試的程序必須通過單元測試。
5. 可重用性要求
5.1 重復(fù)使用的完成相對(duì)獨(dú)立功能的算法或代碼應(yīng)抽象為公共控件或類。
5.2 公共控件或類應(yīng)考慮OO思想,減少外界聯(lián)系,考慮獨(dú)立性或封裝性。
5.3 公共控件或類應(yīng)建立使用模板。
附:C++ 編程規(guī)范,delphi作相應(yīng)的參考
1適用范圍
本標(biāo)準(zhǔn)適用于利用Visul C++ ,Borland C++進(jìn)行軟件程序開發(fā)的人員.。
.2變量命名
命名必須具有一定的實(shí)際意義,形式為xAbcFgh,x由變量類型確定,Abc、Fgh表示連續(xù)意
義字符串,如果連續(xù)意義字符串僅兩個(gè),可都大寫.如OK.
具體例程:
BOOL類型 bEnable;
ch * char chText
c * 類對(duì)象 cMain(對(duì)象實(shí)例)
h * Handle(句柄) hWnd
i * int
n * 無符號(hào)整型
p * 指針
sz,str * 字符串
w WORD
x,y 坐標(biāo)
Char或者TCHAR類型 與Windows API有直接聯(lián)系的用szAppName[10]形式否則用
FileName[10]形式,單個(gè)字符也可用小寫字母表示;
Int類型 nCmdShow;
LONG類型 lParam;
UINT類型 uNotify;
DWORD類型 dwStart;
PSTR類型 pszTip;
LPSTR類型 lpCmdLine
LPTSTR類型 lpszClassName;
LPVOID類型 lpReserved
WPARAM類型 wParam,
LPARAM類型 lParam
HWND類型 hDlg;
HDC類型 hDC;
HINSTANCE類型 hInstance
HANDLE類型 hInstance,
HICON類型 hIcon;
int iTmp
float fTmp
DWORD dw*
String , AnsiString str *
m_ 類成員變量 m_nVal, m_bFlag
g_ 全局變量 g_nMsg, g_bFlag
局部變量中可采用如下幾個(gè)通用變量:nTemp,nResult,I,J(一般用于循環(huán)變量)。
其他資源句柄同上
.3常量命名和宏定義
常量和宏定義必須具有一定的實(shí)際意義;
常量和宏定義在#i nclude和函數(shù)定義之間;
常量和宏定義必須全部以大寫字母來撰寫,中間可根據(jù)意義的連續(xù)性用下劃線連接,每一
條定義的右側(cè)必須有一簡單的注釋,說明其作用;
資源名字定義格式:
菜單:IDM_XX或者CM_XX
位圖:IDB_XX
對(duì)話框:IDD_XX
字符串:IDS_XX
DLGINIT:DIALOG_XX
ICON:IDR_XX
.4函數(shù)命名
函數(shù)原型說明包括引用外來函數(shù)及內(nèi)部函數(shù),外部引用必須在右側(cè)注明函數(shù)來源:模
塊名及文件名, 如是內(nèi)部函數(shù),只要注釋其定義文件名;
第一個(gè)字母必須使用大寫字母,要求用大小寫字母組合規(guī)范函數(shù)命名,必要時(shí)可用下劃線
間隔,示例如下:
void UpdateDB_Tfgd (TRACK_NAME); file://Module Name :r01/sdw.c
void PrintTrackData (TRACK_NAME); file://Module Name :r04/tern.c
void ImportantPoint (void); file://Module Name :r01/sdw.c
void ShowChar (int , int , chtype); file://Local Module
void ScrollUp_V (int , int); file://Local Module
.5結(jié)構(gòu)體命名
結(jié)構(gòu)體類型命名必須全部用大寫字母,原則上前面以下劃線開始;結(jié)構(gòu)體變量命名必須用
大小寫字母組合,第一個(gè)字母必須使用大寫字母,必要時(shí)可用下劃線間隔。對(duì)于私有數(shù)
據(jù)區(qū),必須注明其所屬的進(jìn)程。全局?jǐn)?shù)據(jù)定義只需注意其用途。
示例如下:
typedef struct
{
char szProductName[20];
char szAuthor[20];
char szReleaseDate[16];
char szVersion[10];
unsigned long MaxTables;
unsigned long UsedTables;
}DBS_DATABASE;
DBS_DATABASE GdataBase;
6 控件的命名:
用小寫前綴表示類別
用小寫前綴表示類別:
fm 窗口
cmd 按鈕
cob combo,下拉式列表框
txt 文本輸入框
lab labal,標(biāo)簽
img image,圖象
pic picture
grd Grid,網(wǎng)格
scr 滾動(dòng)條
lst 列表框
frm fram
7注釋
原則上注釋要求使用中文;
文件開始注釋內(nèi)容包括:公司名稱、版權(quán)、作者名稱、時(shí)間、模塊用途、背景介紹等,復(fù)
雜的算法需要加上流程說明;
函數(shù)注釋包括:輸入、輸出、函數(shù)描述、流程處理、全局變量、調(diào)用樣例等,復(fù)雜的函數(shù)
需要加上變量用途說明;
程序中注釋包括:修改時(shí)間和作者、方便理解的注釋等;
引用一: 文件開頭的注釋模板
/******************************************************************
** 文件名:
** Copyright (c) 1998-1999 *********公司技術(shù)開發(fā)部
** 創(chuàng)建人:
** 日 期:
** 修改人:
** 日 期:
** 描 述:
**
** 版 本:
**--------------------------------------------------------------------------
---
******************************************************************/
引用二: 函數(shù)開頭的注釋模板
/*****************************************************************
** 函數(shù)名:
** 輸 入: a,b,c
** a---
** b---
** c---
** 輸 出: x---
** x 為 1, 表示...
** x 為 0, 表示...
** 功能描述:
** 全局變量:
** 調(diào)用模塊:
** 作 者:
** 日 期:
** 修 改:
** 日 期:
** 版本
****************************************************************/
引用三: 程序中的注釋模板
/*----------------------------------------------------------*/
/* 注釋內(nèi)容 */
/*----------------------------------------------------------*/
8 程序
a. 程序編碼力求簡潔,結(jié)構(gòu)清晰,避免太多的分支結(jié)構(gòu)及太過于技巧性的程序,
盡量不采用遞歸模式。
b. 編寫程序時(shí),亦必須想好測試的方法,換句話說,”單元測試” 的測試方案應(yīng)
在程序編寫時(shí)一并擬好。
c. 注釋一定要與程序一致。
d. 版本封存以后的修改一定要將老語句用/* */ 封閉,不能自行刪除或修改,并要
在文件及函數(shù)的修改記錄中加以記錄。
e. 程序中每個(gè)block 的開頭 ”{" 及 "}” 必須對(duì)齊,嵌套的block 每進(jìn)一套,
縮進(jìn)一個(gè)tab,TAB 為4個(gè)空格,block類型包括if、for、while、do等關(guān)鍵字引出的。
f. 對(duì)于比較大的函數(shù),每個(gè)block 和特殊的函數(shù)調(diào)用,都必須注明其功能,舉例如下
:
count.divisor = 1193280 / freq; // compute the proper count
OutByte((unsigned short)67, (unsigned char)182); // tell 8253 that a
count is coming
OutByte((unsigned short)66, count. c[0]); // send low-order byte
OutByte((unsigned short)66, count. c[1]); // send high-order byte
×××××××××××××××××××××××××××××××××××××××
bcb,delphi中的變量命名:
遵循匈牙利命名法,命
名必須有意義,制定如下規(guī)定
窗體:以大寫的W開始,如About版權(quán)窗體, 命名為WAbout
文件:以大寫的F開始,如About版權(quán)窗體,文件命名為FAbout.cpp
按鈕(Button):如退出按鈕,命名為btnExit
……
基類:加base標(biāo)記,如報(bào)表基類,窗體命名為:WBaseRep, 文件命名為FBaseRep.cpp
轉(zhuǎn)貼
> 1. 在.h/.cpp的開頭應(yīng)有一段格式統(tǒng)一的說明,內(nèi)容包括:
> a. 文件名 (FileName);
> b. 創(chuàng)建人 (Creater);
> c. 文件創(chuàng)建時(shí)間 (Date);
> d. 簡短說明文件功能、用途 (Comment)。
好習(xí)慣
> 2. 除非極其簡單,否則對(duì)函數(shù)應(yīng)有注釋說明。內(nèi)容包括:功能、入口/出口參數(shù),必
要
> 時(shí)還可有備注或補(bǔ)充說明。
還是好習(xí)慣
> 3. 每列代碼的長度推薦為 80列,最長不得超過120列;折行以對(duì)齊為準(zhǔn)。
太寬了,我的限制是60列,因?yàn)槲谋痉绞较缕聊灰还?0列,如果你用BC這一類的編輯
器,窗口邊框等又要占據(jù)一定空間,所以80列太寬
> 4. 循環(huán)、分支代碼,判斷條件與執(zhí)行代碼不得在同一行上。
很對(duì)
> 5. 指針的定義,* 號(hào)既可以緊接類型,也可以在變量名之前。
>
> 例:可寫做:int* pnsize;
>
> 也可寫做:int *pnsize;
>
> 但不得寫做:int * pnsize;
建議采用第二種,除非附加另外一條規(guī)定:一次只聲明一個(gè)變量,否則就會(huì)讓人混淆,
比如:
int* a, b;
看起來b好像也是個(gè)指針,其實(shí)不是。
> 6. 在類的成員函數(shù)內(nèi)調(diào)用非成員函數(shù)時(shí),在非成員函數(shù)名前必須加上"::"。
這一條我倒覺得并不是必需的,我的看法是決不要讓你的類成員函數(shù)和全局函數(shù)的名稱
相同(或類似)
> 7. 函數(shù)入口參數(shù)有缺省值時(shí),應(yīng)注釋說明。
>
> 例:BOOL CWpsDib::PaintDIB(CDC* pDC, CRect& rc,
> int nBrightness, file://*=0*//
> BOOL bGrayScale file://*=FALSE*// )
每個(gè)變量寫一行,必要時(shí)加上/*in, out*/注釋
> 8. else if 必須寫在一行。
應(yīng)該盡量避免else if這樣的結(jié)構(gòu)
> 9. 與‘{’、‘}’有關(guān)的各項(xiàng)規(guī)定:
>
> 9.1‘{’、‘}’應(yīng)獨(dú)占一行。在該行內(nèi)可有注釋。
> 9.2 ‘{’必須另起一行,‘{’ 之后的代碼必須縮進(jìn)一個(gè)Tab。‘{’與‘}’必須在
同
> 一列上。
> 9.3 在循環(huán)、分支之后若只有一行代碼,雖然可省略‘{’、‘}’,但不推薦這么
> 做。若省略后可能引起歧義,則必須加上‘{’、‘}’。
持保留意見,因?yàn)镚NU的代碼規(guī)范是這樣的:
if ( NULL == ptr )
{
// do something here
}
或者
if ( NULL == ptr ) {
// do something here
}
爭論哪個(gè)更好并沒有意義,關(guān)鍵是統(tǒng)一,如果用VC當(dāng)然你的辦法最方便,可是如果你用
emacs或者vi,就不是這樣了。
> 10. 與空格有關(guān)的各項(xiàng)規(guī)定。
>
> 10.1 在所有兩目、三目運(yùn)算符的兩邊都必須有空格。在單目運(yùn)算符兩端不必空格。
但
> 在‘—>’、‘::’、‘.’、‘[’、‘]’等運(yùn)算符前后,及‘&’(取地址)、‘*
> ’(取值)等運(yùn)算符之后不得有空格。
> 10.2 for、while、if 等關(guān)鍵詞之后應(yīng)有1個(gè)空格,再接‘(’,之后無空格;在結(jié)
尾
> 的‘)’前不得有空格。
我認(rèn)為在括號(hào)兩端加空格并不是什么錯(cuò)誤,尤其是在一個(gè)條件十分復(fù)雜的if語句里
> 10.3 調(diào)用函數(shù)、宏時(shí),‘(’、‘)’前后不得有空格。
> 10.4 類型強(qiáng)制轉(zhuǎn)換時(shí),‘(’‘)’前后不得有空格
同上
> 11. 與縮進(jìn)有關(guān)的各項(xiàng)規(guī)定
>
> 11.1 縮進(jìn)以 Tab 為單位。1 個(gè) Tab 為 4 個(gè)空格
我認(rèn)為這個(gè)值應(yīng)該更大,我自己使用8個(gè)空格,如果你的代碼因?yàn)榭s進(jìn)幅度太大而導(dǎo)致
折行,那么幾乎可以肯定你的程序設(shè)計(jì)方案有問題。
> 11.2 下列情況,代碼縮進(jìn)一個(gè) Tab:
> 1. 函數(shù)體相對(duì)函數(shù)名及'{'、'}'。
> 2. if、else、for、while、do 等之后的代碼。
> 3. 一行之內(nèi)寫不下,折行之后的代碼,應(yīng)在合理的位置進(jìn)行折行。若有 + - * / 等
運(yùn)
> 算符,則運(yùn)算符應(yīng)在上一行末尾,而不應(yīng)在下一行的行首。
這一條我反對(duì),運(yùn)算符應(yīng)該放在下一行行首,以使人能清楚的知道這一行是續(xù)上一行
的,比如
if ( something
&& somethingelse
&& otherthings )
如果寫做
if ( something &&
somethingelse &&
otherthings )
反而看不清楚
> 11.3 下列情況,不必縮進(jìn):switch 之后的 case、default。
評(píng)論
查看更多