版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
代碼規(guī)范試用稿哈爾濱工業(yè)大學(xué)計(jì)算機(jī)科學(xué)與技術(shù)學(xué)院蘇小紅
sxh@1關(guān)于代碼風(fēng)格問題代碼風(fēng)格(CodingStyle)是一種習(xí)慣現(xiàn)在許多大公司都對員工書寫代碼制定了規(guī)范開發(fā)大項(xiàng)目時由項(xiàng)目管理者制定代碼規(guī)范程序風(fēng)格的重要構(gòu)成因素程序版式命名規(guī)則函數(shù)設(shè)計(jì)原則其他表達(dá)式規(guī)則與零比較常量規(guī)則動態(tài)數(shù)組內(nèi)存管理程序版式程序版式——程序員的書法比書法好學(xué)得多,基本不需要特別練習(xí)但是壞習(xí)慣一旦養(yǎng)成,就像書法一樣難以改變不影響程序的功能,但影響程序的可讀性追求清晰、整潔、美觀、一目了然容易閱讀,容易測試程序版式不良的風(fēng)格int
isprime(intn){int
k,i;if(n==1)return0;k=sqrt((double)n);for(i=2;i<=k;i++){if(n%i==0)return0;}return1;}#include<stdio.h>#include<math.h>main(){inti;for(i=2;i<100;i++){if(isprime(i))printf("%d\t",i);}}程序版式良好的風(fēng)格int
isprime(intn){
intk,i; if(n==1)return0; k=(int)sqrt((double)n);
for(i=2;i<=k;i++){
if(n%i==0)
return0;}
return1;}#include<stdio.h>#include<math.h>main(){
inti;
for(i=2;i<100;i++){
if(isprime(i))
printf("%d\t",i);}}程序版式對齊(Alignment)與縮進(jìn)(indent)——保證代碼整潔、層次清晰的主要手段“{”位置的兩種風(fēng)格{和}獨(dú)占一行,且位于同一列,與引用它們的語句左對齊,便于檢查配對情況位于同一層{和}之內(nèi)的代碼在{右邊數(shù)格處左對齊,即同層次的代碼在同層次的縮進(jìn)層上一般用設(shè)置為4個空格的Tab鍵縮進(jìn),不用空格縮進(jìn)voidFunction(intx){…//programcode}voidFunction(intx){…//programcode}if(condition){…//programcode}else{…//programcode}if(condition){…//programcode}else{…//programcode}for(initialization;condition;update){…//programcode}for(initialization;condition;update){…//programcode}while(condition){…//programcode}while(condition){…//programcode}如果出現(xiàn)嵌套的{},則使用縮進(jìn)對齊,如:
{ … { … } …}建議的風(fēng)格不建議的風(fēng)格程序版式現(xiàn)在的許多開發(fā)環(huán)境、編輯軟件都支持“自動縮進(jìn)”根據(jù)用戶代碼的輸入,智能判斷應(yīng)該縮進(jìn)還是反縮進(jìn),替用戶完成調(diào)整縮進(jìn)的工作VC中有自動整理格式功能只要選取需要的代碼,按ALT+F8就能自動整理成微軟的cpp文件格式程序版式變量的對齊規(guī)則數(shù)據(jù)類型+N個TAB+變量名+[N個TAB]+=+[初始化值];例charname[20];charaddr[30];charsex='F';intage=20;floatscore=90;程序版式空行——分隔程序段落的作用在每個類聲明之后加空行在每個函數(shù)定義結(jié)束之后加空行在一個函數(shù)體內(nèi),相鄰兩組邏輯上密切相關(guān)的語句塊之間加空行,語句塊內(nèi)不加空行//空行voidFunction1(…){…}//空行voidFunction2(…){…}//空行voidFunction3(…){…}//空行while(condition){ statement1; //空行
if(condition) { statement2; } else { statement3; }//空行
statement4;}程序版式代碼行內(nèi)的空格——增強(qiáng)單行清晰度關(guān)鍵字之后加空格函數(shù)名之后不加空格賦值、算術(shù)、關(guān)系、邏輯等二元運(yùn)算符前后各加一空格,但一元運(yùn)算符前后一般不加空格sum=sum+term;(向后緊跟,),;向前緊跟,緊跟處不留空格,;后留一個空格Function(x,y,z)for(initialization;condition;update)[].->前后不加空格對表達(dá)式較長的for和if語句,為了緊湊可在適當(dāng)?shù)胤饺サ粢恍┛崭駀or(i=0;i<10;i++)if((a+b>c)&&(b+c>a)&&(c+a>b))voidFunc1(intx,inty,intz);//良好的風(fēng)格voidFunc1(int
x,int
y,intz);//不良的風(fēng)格printf("%d%d%d",a,b,c);//良好的風(fēng)格printf("%d%d%d",a,b,c);//不良的風(fēng)格if(year>=2000)//良好的風(fēng)格if(year>=2000)//不良的風(fēng)格if((a>=b)&&(c<=d))//良好的風(fēng)格if(a>=b&&c<=d)//不良的風(fēng)格for(i=0;i<10;i++)//良好的風(fēng)格for(i=0;i<10;i++)//不良的風(fēng)格for(i=0;i<10;i++)//過多的空格x=a<b?a:b;//良好的風(fēng)格x=a<b?a:b;//不良的風(fēng)格int*x=&y;//良好的風(fēng)格int*x=&y;//不良的風(fēng)格array[5]=0;//不要寫成array[5]=0;a.Function();//不要寫成a.Function();b->Function();//不要寫成b->Function();程序版式程序版式代碼行一行只寫一條語句,這樣方便測試一行只寫一個變量,這樣方便寫注釋intwidth;//寬度intheight;//高度intdepth;//深度盡可能在定義變量的同時,初始化該變量intsum=0;if、for、while、do等語句各占一行,執(zhí)行語句無論有幾條都用{和}將其包含在內(nèi),這樣便于維護(hù)if(width<height){
DoSomething();}//空行OtherThing();intwidth; //寬度intheight; //高度intdepth; //深度intwidth,height,depth;//寬度高度深度x=a+b;y=c+d;z=e+f;x=
a+b;y=c+d;z=e+f;if(width<height){
dosomething();}if(width<height)dosomething();for(initialization;condition;update){
dosomething();}//空行other();for(initialization;condition;update)
dosomething();other();程序版式程序版式長行拆分代碼行不宜過長,應(yīng)控制在70-~80個字符以內(nèi)實(shí)在太長時要在適當(dāng)位置拆分,拆分出的新行要進(jìn)行適當(dāng)縮進(jìn)if((veryLongVar1>=veryLongVar2)&&(veryLongVar3>=veryLongVar4)){
DoSomething();}doubleFunctionName(doublevariablename1,doublevariablename2);for(very_longer_initialization;
very_longer_condition;
very_longer_update){
DoSomething();}程序版式修飾符*和&的位置有爭議從語義上講,靠近數(shù)據(jù)類型更直觀,但對多個變量聲明時容易引起誤解int*x,y;提倡靠近變量名int*x,y;注釋規(guī)范注釋(Comments)的重要性寫注釋給誰看?在哪些地方寫注釋?怎樣寫注釋?注釋的風(fēng)格寫注釋時的注意事項(xiàng)可靈活運(yùn)用的一些規(guī)則注釋規(guī)范注釋的重要性注釋對于程序猶如眼睛對于人的重要性一樣沒有注釋的程序?qū)τ谧x者好比眼前一團(tuán)漆黑,跟拿到一個可執(zhí)行程序別無二致不規(guī)范的注釋和好幾千度的近似眼沒什么區(qū)別代碼本身體現(xiàn)不出價值開發(fā)程序的思維才能使其變得有價值這種思維的具體體現(xiàn)就是在于注釋和規(guī)范的代碼本身注釋規(guī)范寫注釋給誰看?給自己看,使自己的設(shè)計(jì)思路得以連貫給繼任者看,使其能夠接替自己的工作注釋規(guī)范寫注釋的最重要的功效在于傳承要站在繼任者的角度寫簡單明了、準(zhǔn)確易懂、防止二義性讓繼任者可以輕松閱讀、復(fù)用、修改自己的代碼讓繼任者輕松辨別出哪些使自己寫的,哪些是別人寫的注釋規(guī)范不好的注釋i=i+1; //i加1return-1;//返回-1free(p); //釋放p所指的內(nèi)存fclose(fin); //關(guān)閉文件/******************************************/ /*功能描述:本函數(shù)用于實(shí)現(xiàn)xxx功能,目的是: *//*入口參數(shù):參數(shù)p,表示指向結(jié)構(gòu)體的指針 *//*出口參數(shù):參數(shù)xx,表示 *//*返回值:返回xx值,當(dāng)返回xx值時,表示 */ /******************************************/注釋規(guī)范不好的注釋不但白寫,還擾亂了讀者的視線/*以二進(jìn)制只讀方式打開文件并判斷打開是否成功*/if((fin=fopen("cat.pic","rb")==NULL){puts("打開文件cat.pic失敗");/*如果打開失敗,則顯示錯誤信息*/
return-1;/*返回-1*/}……/*從圖像的第1行到第400行循環(huán)*/for(i=0;i<400;i++)/*從圖像的第1列到第400列循環(huán)*/
for(j=0;j<400;j++){……/*按照公式Y(jié)=0.299*R+0.587*G+0.114*B計(jì)算灰度值*/y=(299*r+587*g+114*b)/1000;……}……fclose(fin);/*關(guān)閉文件*/注釋規(guī)范好的注釋(尤其是算法注釋)是對設(shè)計(jì)思想的精確表述和清晰展現(xiàn),能揭示代碼背后隱藏的重要信息/*打開輸入文件后判斷文件長度是否符合格式要求*/if((fin=fopen("cat.pic","rb")==NULL){puts("打開文件cat.pic失敗");
return-1;}……/**下面是圖像轉(zhuǎn)換的算法實(shí)現(xiàn)。彩色圖像到灰度圖像的轉(zhuǎn)換主要利用RGB顏色空間到*YUV顏色空間的變換公式來取得灰度值,公式為Y=0.299*R+0.587*G+0.114*B*/for(i=0;i<400;i++)
for(j=0;j<400;j++){……y=(299*r+587*g+114*b)/1000;……}……fclose(fin);注釋規(guī)范在哪些地方寫注釋?在重要的文件首部文件名+功能說明+[作者]+[版本]+[版權(quán)聲明]+[日期]在用戶自定義函數(shù)前對函數(shù)接口進(jìn)行說明函數(shù)功能+入口參數(shù)+出口參數(shù)+返回值(包括出錯處理)在一些重要的語句塊上方對代碼的功能、原理進(jìn)行解釋說明在一些重要的語句行右方定義一些非通用的變量函數(shù)調(diào)用較長的、多重嵌套的語句塊結(jié)束處在修改的代碼行旁邊加注釋注釋規(guī)范函數(shù)的注釋風(fēng)格C風(fēng)格/**********************************************/ /*功能描述:本函數(shù)用于實(shí)現(xiàn)xxx功能,目的是: *//*入口參數(shù):參數(shù)xx,表示 *//*出口參數(shù):參數(shù)xx,表示 *//*返回值:返回xx值,當(dāng)返回xx值時,表示 */ /**********************************************//*功能描述:本函數(shù)用于實(shí)現(xiàn)xxx功能,目的是:
入口參數(shù):參數(shù)xx,表示
出口參數(shù):參數(shù)xx,表示
返回值:返回xx值,當(dāng)返回xx值時,表示
*/C++風(fēng)格////////////////////////////////////////// //功能描述:本函數(shù)用于實(shí)現(xiàn)xxx功能,目的是://入口參數(shù):參數(shù)xx,表示 //出口參數(shù):參數(shù)xx,表示 //返回值:返回xx值,當(dāng)返回xx值時,表示
//////////////////////////////////////////注釋規(guī)范一塊語句的注釋風(fēng)格/* *C風(fēng)格 */C風(fēng)格/********************************/ /*下面代碼是用來接收網(wǎng)絡(luò)數(shù)據(jù),其原理為*/ /*……*/ /********************************/////////////////////////////////// //VisualC++風(fēng)格// //////////////////////////////////注釋規(guī)范一行語句的注釋風(fēng)格/*C風(fēng)格*///VisualC++風(fēng)格i=j+1;//代碼行右方的注釋//代碼行之上的注釋 i=j+1;例子ResetSrollInfo(g_hwndThumb);//初始化滾動條位置for循環(huán) { while循環(huán) { if() {……}//if結(jié)束 }//while結(jié)束 }//for結(jié)束注釋規(guī)范寫注釋時的注意事項(xiàng)注釋不是白話文翻譯,不要鸚鵡學(xué)舌注釋不是教科書,不要把別人當(dāng)成初學(xué)者注釋不是標(biāo)準(zhǔn)庫函數(shù)參考手冊注釋不是越多越好,不好的注釋等于垃圾不寫做了什么,寫想做什么邊寫代碼邊注釋修改代碼同時修改注釋注釋規(guī)范可靈活運(yùn)用的一些規(guī)則注釋可長可短,但應(yīng)畫龍點(diǎn)睛,重點(diǎn)加在語義轉(zhuǎn)折處簡單的函數(shù)可以用一句話簡單說明//兩數(shù)交換voidSwap(int*x,int*y)內(nèi)部使用的函數(shù)可以簡單注釋,供別人使用的函數(shù)必須嚴(yán)格注釋,特別是入口參數(shù)和出口參數(shù)Readme的書寫內(nèi)容主要用來記錄日期、創(chuàng)建者、內(nèi)容等每次重大功能的添加、修改具體格式:日期—TAB—創(chuàng)建者—TAB—內(nèi)容日期:2003.1.21 創(chuàng)建者:XXX 內(nèi)容:實(shí)例工程日期—TAB—修改的文件名—TAB—修改的功能對修改后的功能和原理的說明……日期—TAB—修改的文件名—TAB—修改的功能對修改后的功能和原理的說明類的版式“以數(shù)據(jù)為中心”的版式private類型的數(shù)據(jù)寫在前面,public類型的數(shù)據(jù)寫在后面關(guān)注類的內(nèi)部結(jié)構(gòu)“以行為為中心”的版式public類型的數(shù)據(jù)寫在前面,private類型的數(shù)據(jù)寫在后面關(guān)注的是類應(yīng)該提供什么樣的接口(或服務(wù))提倡后者因?yàn)橛脩糇铌P(guān)心的是接口標(biāo)識符命名規(guī)則按照執(zhí)行級別分為:共性規(guī)則必須執(zhí)行簡化規(guī)則建議采用可選規(guī)則靈活運(yùn)用標(biāo)識符命名的共性規(guī)則直觀可以拼讀,見名知意,不必解碼最好采用英文單詞或其組合,切忌用漢語拼音盡量避免出現(xiàn)數(shù)字編號不要出現(xiàn)僅靠大小寫區(qū)分的相似的標(biāo)識符不要出現(xiàn)名字完全相同的局部變量和全局變量用正確的反義詞組命名具有互斥意義的變量或相反動作的函數(shù)int
minValue;int
maxValue;int
GetValue(…);int
SetValue(…);標(biāo)識符命名的共性規(guī)則盡量與所采用的操作系統(tǒng)或開發(fā)工具的風(fēng)格保持一致在Linux/Unix平臺習(xí)慣用“小寫加下劃線”function_name
variable_NameWindows風(fēng)格大小寫混排的單詞組合而成FunctionName
variableNameWindows應(yīng)用程序命名規(guī)則Microsoft公司的HungarianNotation主要思想在變量和函數(shù)名前加上前綴,用于標(biāo)識變量的數(shù)據(jù)類型[限定范圍的前綴]+[數(shù)據(jù)類型前綴]+[有意義的英文單詞]限定范圍的前綴靜態(tài)變量前加前綴s_
,表示static全局變量前加前綴g_
,表示global類內(nèi)的成員函數(shù)m_默認(rèn)情況為局部變量數(shù)據(jù)類型前綴ch
字符變量前綴i整型變量前綴f實(shí)型變量前綴p指針變量前綴Windows應(yīng)用程序命名規(guī)則缺點(diǎn)煩瑣例如inti,j,k;floatx,y,z;若采用匈牙利命名規(guī)則,則應(yīng)寫成int
iI,iJ,ik;//前綴i表示int類型float
fX,fY,fZ;//前綴f表示float類型簡化的Windows應(yīng)用程序命名規(guī)則變量名形式小寫字母開頭“名詞”或者“形容詞+名詞”如oldValue,newValue等函數(shù)名形式大寫字母開頭“動詞”或者“動詞+名詞”(動賓詞組)如GetValue(),SetValue()等宏和const常量全用大寫字母,并用下劃線分割單詞#define
ARRAY_LEN10constint
MAX_LEN=100;靈活運(yùn)用的命名規(guī)則限定范圍的前綴與數(shù)據(jù)類型前綴可要可不要無特殊意義的循環(huán)變量可以直接定義成i,j,k等單字母變量表達(dá)式規(guī)則盡量簡單,不要太復(fù)雜不要多用途a=i+++i+++i++;printf("%d,%d,%d",i++,i++,i++);不要與數(shù)學(xué)表達(dá)式混淆if(a<b<c)不表示if((a<b)&&(b<c))無需背誦的規(guī)則運(yùn)算符優(yōu)先級先算括號用括號確定表達(dá)式的操作順序,避免使用默認(rèn)的優(yōu)先級庫函數(shù)用法會查聯(lián)機(jī)幫助、手冊最重要需要考慮移植性的問題不同平臺,不同編譯器,可能會迥然不同凡是需要字節(jié)數(shù)的地方,一律用sizeof獲得與零比較的規(guī)則布爾變量與零比較不應(yīng)寫成if(flag==0)if(flag!=0)應(yīng)寫成if(flag)//表示flag為真if(!flag)//表示flag為假與零比較的規(guī)則整型變量與零比較不應(yīng)寫成if(value)//容易誤解為布爾變量if(!value)應(yīng)寫成if(value==0)if(value!=0)寫成如下形式能防止==誤寫為=if(0==value)if(0!=value)與零比較的規(guī)則實(shí)型變量與零比較不應(yīng)寫成if(x==0.0)//float和double變量都有精度限制應(yīng)寫成if((x>=-EPS)&&((x<=EPS))if(fabs(x)<=EPS)與零比較的規(guī)則指針變量與零比較不應(yīng)寫成if(p==0)//容易誤解為整型變量if(p!=0)if(p)//容易誤解為布爾變量if(!p)應(yīng)寫成if(p==NULL)//強(qiáng)調(diào)p是指針變量if(p!=NULL)常量規(guī)則盡量使用含義直觀的常量來表示多次出現(xiàn)的數(shù)字或者字符串#definePI3.14159constfloatPI=3.14159;C++中用const常量完全取代宏常量需要對外公開的常量集中放在一個公共的頭文件中,不需要對外公開的常量放在定義文件的頭部常量規(guī)則怎樣建立在類中恒定,且僅在類中有效的常量?#define定義的宏常量是全局的const數(shù)據(jù)成員可以嗎?常量規(guī)則class
A{…
constintSIZE=100;//不能在類聲明中初始化const數(shù)據(jù)成員
int
array[SIZE];//類的對象未被創(chuàng)建時,SIZE值未知};const數(shù)據(jù)成員只能在類構(gòu)造函數(shù)的初始化表中進(jìn)行class
A{…
A(intsize);//構(gòu)造函數(shù)
const
int
SIZE;};A::A(int
size):SIZE(size){…}Aa(100);//對象a的SIZE值為100Ab(200);//對象b的SIZE值為200常量規(guī)則怎樣建立在整個類中都恒定的常量呢?const數(shù)據(jù)成員只在某個對象生存期內(nèi)是常量,而對類而言是可變的因?yàn)轭惪梢詣?chuàng)建多個對象不同對象的const數(shù)據(jù)成員值不同不能指望const數(shù)據(jù)成員了常量規(guī)則怎樣建立在整個類中都恒定的常量呢?應(yīng)該用類中的枚舉常量來實(shí)現(xiàn) class
A{…
enum{SIZE1=100,SIZE2=200};
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2024年水上加油柴油運(yùn)輸服務(wù)合同
- 共同合作采購合同范例
- 廣西招投標(biāo)合同范例
- 物業(yè)水箱拆除合同范例
- 設(shè)備安裝合同合同范例
- 2024年標(biāo)準(zhǔn)工程材料供應(yīng)與承包合同版B版
- 商場賣家具合同范例
- 大菜市租房合同范例
- 水店加盟合同范例
- 健身合同范例
- 中藥涂擦治療
- 2023-2024學(xué)年廣東省深圳市福田區(qū)八年級(上)期末英語試卷
- 2024年高考物理復(fù)習(xí)試題分類訓(xùn)練:動量(教師卷)
- 2024年軍事理論知識全冊復(fù)習(xí)題庫及答案
- FA合同協(xié)議模板新
- 幼兒園安全風(fēng)險(xiǎn)分級管控和隱患排查治理雙重預(yù)防機(jī)制實(shí)施方案
- 餐飲服務(wù)電子教案 學(xué)習(xí)任務(wù)3 西餐宴會服務(wù)
- 石橫鎮(zhèn)衛(wèi)生院康復(fù)科建設(shè)方案
- DB11T 1553-2018 居住建筑室內(nèi)裝配式裝修工程技術(shù)規(guī)程
- 非新生兒破傷風(fēng)診療
- 建筑施工企業(yè)八大員繼續(xù)教育模擬考試題庫500題(含標(biāo)準(zhǔn)答案)
評論
0/150
提交評論