代碼審查表格模板_第1頁(yè)
代碼審查表格模板_第2頁(yè)
代碼審查表格模板_第3頁(yè)
代碼審查表格模板_第4頁(yè)
代碼審查表格模板_第5頁(yè)
全文預(yù)覽已結(jié)束

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

代碼審查表文件結(jié)構(gòu)重要性

審查項(xiàng)

頭文件和定義文件的名稱是否合理?

頭文件和定義文件的目錄結(jié)構(gòu)是否合理?

版權(quán)和版本聲明是否完整?重要

頭文件是否使用了ifndef/define/endif預(yù)處理塊?

頭文件中是否只存放“聲明”而不存放“定義”程序的版式重要性

審查項(xiàng)

空行是否得體?

代碼行內(nèi)的空格是否得體?

長(zhǎng)行拆分是否得體?

“{”和“}”是否各占一行并且對(duì)齊于同一列?重要

一行代碼是否只做一件事?如只定義一個(gè)變量,只寫(xiě)一條語(yǔ)句。重要

If、for、while、do等語(yǔ)句自占一行,不論執(zhí)行語(yǔ)句多少都要加“{}”。重要

在定義變量(或參數(shù))時(shí),是否將修飾符*和&緊靠變量名?注釋是否清晰并且必要?重要

注釋是否有錯(cuò)誤或者可能導(dǎo)致誤解?重要

類結(jié)構(gòu)的public,protected,private順序是否在所有的程序中保持一致?命名規(guī)則重要性

審查項(xiàng)重要

命名規(guī)則是否與所采用的操作系統(tǒng)或開(kāi)發(fā)工具的風(fēng)格保持一致?

標(biāo)識(shí)符是否直觀且可以拼讀?

標(biāo)識(shí)符的長(zhǎng)度應(yīng)當(dāng)符合“min-length&&max-information”原則?重要

程序中是否出現(xiàn)相同的局部變量和全部變量?

類名、函數(shù)名、變量和參數(shù)、常量的書(shū)寫(xiě)格式是否遵循一定的規(guī)則?

靜態(tài)變量、全局變量、類的成員變量是否加前綴?表達(dá)式與基本語(yǔ)句重要性

審查項(xiàng)重要

如果代碼行中的運(yùn)算符比較多,是否已經(jīng)用括號(hào)清楚地確定表達(dá)式的操作順序?

是否編寫(xiě)太復(fù)雜或者多用途的復(fù)合表達(dá)式?重要

是否將復(fù)合表達(dá)式與“真正的數(shù)學(xué)表達(dá)式”混淆?重要

是否用隱含錯(cuò)誤的方式寫(xiě)if語(yǔ)句?例如

(1)將布爾變量直接與TRUE、FALSE或者1、0進(jìn)行比較。

(2)將浮點(diǎn)變量用“==”或“!=”與任何數(shù)字比較。

(3)將指針變量用“==”或“!=”與NULL比較。

如果循環(huán)體內(nèi)存在邏輯判斷,并且循環(huán)次數(shù)很大,是否已經(jīng)將邏輯判

斷移到循環(huán)體的外面?重要

Case語(yǔ)句的結(jié)尾是否忘了加break?重要

是否忘記寫(xiě)switch的default分支?重要

使用goto語(yǔ)句時(shí)是否留下隱患?例如跳過(guò)了某些對(duì)象的構(gòu)造、變量的初始化、重要的計(jì)算等。常量重要性

審查項(xiàng)

是否使用含義直觀的常量來(lái)表示那些將在程序中多次出現(xiàn)的數(shù)字或字符串?

在C++程序中,是否用const常量取代宏常量?重要

如果某一常量與其它常量密切相關(guān),是否在定義中包含了這種關(guān)系?

是否誤解了類中的const數(shù)據(jù)成員?因?yàn)閏onst數(shù)據(jù)成員只在某個(gè)對(duì)象

生存期內(nèi)是常量,而對(duì)于整個(gè)類而言卻是可變的。函數(shù)設(shè)計(jì)重要性

審查項(xiàng)

參數(shù)的書(shū)寫(xiě)是否完整?不要貪圖省事只寫(xiě)參數(shù)的類型而省略參數(shù)名字。

參數(shù)命名、順序是否合理?

參數(shù)的個(gè)數(shù)是否太多?

是否使用類型和數(shù)目不確定的參數(shù)?

是否省略了函數(shù)返回值的類型?

函數(shù)名字與返回值類型在語(yǔ)義上是否沖突?重要

是否將正常值和錯(cuò)誤標(biāo)志混在一起返回?正常值應(yīng)當(dāng)用輸出參數(shù)獲得,而錯(cuò)誤標(biāo)志用return語(yǔ)句返回。重要

在函數(shù)體的“入口處”,是否用assert對(duì)參數(shù)的有效性進(jìn)行檢查?重要

使用濫用了assert?例如混淆非法情況與錯(cuò)誤情況,后者是必然存在的并且是一定要作出處理的。重要

return語(yǔ)句是否返回指向“棧內(nèi)存”的“指針”或者“引用”?

是否使用const提高函數(shù)的健壯性?const可以強(qiáng)制保護(hù)函數(shù)的參數(shù)、返回值,甚至函數(shù)的定義體?!癠seconstwheneveryou

need”內(nèi)存管理重要性

審查項(xiàng)重要

用malloc或new申請(qǐng)內(nèi)存之后,是否立即檢查指針值是否為NULL?(防止使用指針值為NULL的內(nèi)存)重要

是否忘記為數(shù)組和動(dòng)態(tài)內(nèi)存賦初值?(防止將未被初始化的內(nèi)存作為右值使用)重要

數(shù)組或指針的下標(biāo)是否越界?重要

動(dòng)態(tài)內(nèi)存的申請(qǐng)與釋放是否配對(duì)?(防止內(nèi)存泄漏)重要

是否有效地處理了“內(nèi)存耗盡”問(wèn)題?重要

是否修改“指向常量的指針”的內(nèi)容?重要

是否出現(xiàn)野指針?例如

(1)指針變量沒(méi)有被初始化。

(2)用free或delete釋放了內(nèi)存之后,忘記將指針設(shè)置為NULL。重要

是否將malloc/free和new/delete混淆使用?重要

malloc語(yǔ)句是否正確無(wú)誤?例如字節(jié)數(shù)是否正確?類型轉(zhuǎn)換是否正確?重要

在創(chuàng)建與釋放動(dòng)態(tài)對(duì)象數(shù)組時(shí),new/delete的語(yǔ)句是否正確無(wú)誤?C++函數(shù)的高級(jí)特性重要性

審查項(xiàng)

重載函數(shù)是否有二義性?重要

是否混淆了成員函數(shù)的重載、覆蓋與隱藏?

運(yùn)算符的重載是否符合制定的編程規(guī)范?

是否濫用內(nèi)聯(lián)函數(shù)?例如函數(shù)體內(nèi)的代碼比較長(zhǎng),函數(shù)體內(nèi)出現(xiàn)循環(huán)。重要

是否用內(nèi)聯(lián)函數(shù)取代了宏代碼?類的構(gòu)造函數(shù)、析構(gòu)函數(shù)和賦值函數(shù)重要性

審查項(xiàng)重要

是否違背編程規(guī)范而讓C++編譯器自動(dòng)為類產(chǎn)生四個(gè)缺省的函數(shù):

(1)缺省的無(wú)參數(shù)構(gòu)造函數(shù);

(2)缺省的拷貝構(gòu)造函數(shù);

(3)缺省的析構(gòu)函數(shù);

(4)缺省的賦值函數(shù)。重要

構(gòu)造函數(shù)中是否遺漏了某些初始化工作?重要

是否正確地使用構(gòu)造函數(shù)的初始化表?重要

析構(gòu)函數(shù)中是否遺漏了某些清除工作?

是否錯(cuò)寫(xiě)、錯(cuò)用了拷貝構(gòu)造函數(shù)和賦值函數(shù)?重要

賦值函數(shù)一般分四個(gè)步驟:

(1)檢查自賦值;

(2)釋放原有內(nèi)存資源;

(3)分配新的內(nèi)存資源,并復(fù)制內(nèi)容;

(4)返回*this。是否遺漏了重要步驟?

重要

是否正確地編寫(xiě)了派生類的構(gòu)造函數(shù)、析構(gòu)函數(shù)、賦值函數(shù)?

注意事項(xiàng):

(1)派生類不可能繼承基類的構(gòu)造函數(shù)、析構(gòu)函數(shù)、賦值函數(shù)。

(2)派生類的構(gòu)造函數(shù)應(yīng)在其初始化表里調(diào)用基類的構(gòu)造函數(shù)。

(3)基類與派生類的析構(gòu)函數(shù)應(yīng)該為虛(即加virtual關(guān)鍵字)。

(4)在編寫(xiě)派生類的賦值函數(shù)時(shí),注意不要忘記對(duì)基類的數(shù)據(jù)成員重新賦值。類的高級(jí)特性重要性

審查項(xiàng)重要

是否違背了繼承和組合的規(guī)則?

(1)若在邏輯上B是A的“一種”,并且A的所有功能和屬性對(duì)B而言都有意義,則允許B繼承A的功能和屬性。

(2)若在邏輯上A是B的“一部分”(apartof),則不允許B從A派生,而是要用A和其它東西組合出B。其它常見(jiàn)問(wèn)題重要性

審查項(xiàng)重要

數(shù)據(jù)類型問(wèn)題:

(1)變量的數(shù)據(jù)類型有錯(cuò)誤嗎?

(2)存在不同數(shù)據(jù)類型的賦值嗎?

(3)存在不同數(shù)據(jù)類型的比較嗎?重要

變量值問(wèn)題:

(1)變量的初始化或缺省值有錯(cuò)誤嗎?

(2)變量發(fā)生上溢或下溢嗎?

(3)變量的精度夠嗎?

重要

邏輯判斷問(wèn)題:

(1)由于精度原因?qū)е卤容^無(wú)效嗎?

(2)表達(dá)式中的優(yōu)先級(jí)有誤嗎?

(3)邏輯判斷結(jié)果顛倒嗎?

重要

循環(huán)問(wèn)題:

(1)循環(huán)終止條件不正確嗎?

(2)無(wú)法正常終止(死循環(huán))嗎?

(3)錯(cuò)誤地修改循環(huán)變量嗎?

(4)存在誤差累積嗎?

重要

錯(cuò)誤處理問(wèn)題:

(1)忘記進(jìn)行錯(cuò)誤處理嗎?

(2)錯(cuò)誤處理程序塊一直沒(méi)有機(jī)會(huì)被運(yùn)行?

(3)錯(cuò)誤處理程序塊本身就有毛病嗎?如報(bào)告的錯(cuò)誤與實(shí)際錯(cuò)誤不

一致,處理方式不

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論