版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認(rèn)領(lǐng)
文檔簡介
1、C#開發(fā)編程規(guī)范(基本要求)1.1程序結(jié)構(gòu)要求:?1.程序結(jié)構(gòu)清晰,簡單易懂,單個函數(shù)的程序行數(shù)不得超過100行。?2.打算干什么,要簡單,直截了當(dāng),代碼精簡,避免垃圾程序。?3.盡量使用.庫函數(shù)和公共函數(shù)(無特殊情況不要使用外部方法調(diào)用windows的核心動態(tài)鏈接庫API)。?4.不要隨意定義全局變量,盡量使用局部變量。1.2可讀性要求:?1.可讀性第一,效率第二(保證后期維護的簡易)。?2.保持注釋與代碼完全一致。?3.每個源程序文
2、件,都有文件頭說明,說明規(guī)格見規(guī)范。?4.每個函數(shù),都有函數(shù)頭(使用XML注釋)說明,說明規(guī)格見規(guī)范。?5.主要變量(結(jié)構(gòu)、聯(lián)合、類或?qū)ο螅┒x或引用時,注釋能反映其含義。?6.處理過程的每個階段都有相關(guān)注釋說明。?7.在典型算法前都有注釋同時算法在滿足要求的情況下盡可能簡單。?8.利用縮進來顯示程序的邏輯結(jié)構(gòu),縮進量一致并以VS自動生成為準(zhǔn),不采用空格進行縮進。?9.循環(huán)、分支層次不要超過五層。?10.注釋可以與語句在同一行,也可以在
3、上行。?11.空行和空白字符也是一種特殊注釋。?12.一目了然的語句不加注釋。?13.注釋的作用范圍可以為:定義、引用、條件分支以及一段代碼。?14.注釋行數(shù)(不包括程序頭和函數(shù)頭說明部份)應(yīng)占總行數(shù)的15到131.3結(jié)構(gòu)化要求:?1.禁止出現(xiàn)兩條等價的支路。?2.除了在Switch關(guān)鍵字的作用域內(nèi),禁止GOTO語句。?3.用IF語句來強調(diào)只執(zhí)行兩組語句中的一組。禁止ELSEGOTO和ELSERETURN。?4.用CASE實現(xiàn)多路分支。
4、?5.避免從循環(huán)引出多個出口。?6.函數(shù)只有一個出口。?7不使用條件賦值語句。?8避免不必要的分支。?9不要輕易用條件分支去替換邏輯表達式1.4正確性與容錯性要求:?1.程序首先是正確,其次是優(yōu)美?2.無法證明你的程序沒有錯誤,因此在編寫完一段程序后,應(yīng)先回頭檢查。?3.改一個錯誤時可能產(chǎn)生新的錯誤,因此在修改前首先考慮對其它程序的影響。?4.所有變量在調(diào)用前必須被初始化。?5.對所有的用戶輸入,必須進行合法性檢查。?6.盡量不要比較浮
5、點數(shù)的相等,如:10.00.1==1.0,不可靠?7.程序與環(huán)境或狀態(tài)發(fā)生關(guān)系時,必須主動去處理發(fā)生的意外事件,如文件能否邏輯鎖定、打印機是否聯(lián)機等對于明確的錯誤要有明確的容錯代碼提示用戶,在這樣不確定的場合都使用TryThrowCatch。?8.單元測試也是編程的一部份,提交聯(lián)調(diào)測試的程序必須通過單元測試。?9.盡量使用規(guī)范的容錯語句.例如:Trycatchfinally1.5.可重用性要求:?1.重復(fù)使用的完成相對獨立功能的算法或代
溫馨提示
- 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. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
評論
0/150
提交評論