網(wǎng)頁重構(gòu)盡量避免使用代碼注釋
來源:易賢網(wǎng) 閱讀:1427 次 日期:2016-07-13 16:30:24
溫馨提示:易賢網(wǎng)小編為您整理了“網(wǎng)頁重構(gòu)盡量避免使用代碼注釋”,方便廣大網(wǎng)友查閱!

一直以來我沒有見過任何科學(xué)研究證明了這一點,但在軟件領(lǐng)域,它就像一個教條或一個共同的信念。由于它的存在,將軟件寫得易于閱讀、關(guān)注代碼的可讀型都是很重要的。通過一些技術(shù)的輔助程序員可以實現(xiàn)這些要求,這些技術(shù)其中之一就是寫代碼注釋。

名單

免責(zé)聲明:我所說的“避免代碼注釋”并不意味著我不寫注釋,這意味著,我盡可能避免寫代碼注釋,但當(dāng)我覺得值得寫時我還是寫的。

“相比寫軟件我們花了更多的時間在閱讀軟件上”,一直以來我沒有見過任何科學(xué)研究證明了這一點,但在軟件領(lǐng)域,它就像一個教條或一個共同的信念。由于它的存在,將軟件寫得易于閱讀、關(guān)注代碼的可讀型都是很重要的。通過一些技術(shù)的輔助程序員可以實現(xiàn)這些要求,這些技術(shù)其中之一就是寫代碼注釋。

當(dāng)談?wù)撈鸫a注釋的時候,有關(guān)的辯論總無休止。我們應(yīng)該用注釋來說明我們代碼的作用嗎,我們應(yīng)該將重點放在代碼的表達性而不需要注釋來輔助閱讀嗎?Joe Kunk為這爭論寫了一篇博客 - 應(yīng)不應(yīng)該寫注釋。有那些人說文檔完備的代碼被認(rèn)為是好代碼,還有些人說應(yīng)該避免注釋,因為注釋通常被用來解釋/隱藏不好的代碼。

在我看來,在書籍的影響下,為確保代碼整潔便于重構(gòu),我們應(yīng)該避免寫注釋,除非我們有一個好的寫注釋的理由(例如數(shù)學(xué)算法)或因為公司要求或流程我們有義務(wù)這樣做。下面是我關(guān)于注釋的五點憂慮。

我認(rèn)為代碼注釋起到反作用的地方

1.注釋往往鼓勵壞的代碼

“注釋的代碼是好代碼”有這樣一個說法,所以人們常常在代碼中添加注釋以代碼漂亮。如果我們?yōu)榱私忉尨a而添加注釋這就像是一個信號:也許我們正在編寫糟糕的代碼。當(dāng)我們要寫一條注釋是,我們應(yīng)該想是否能夠通過清理代碼使它更有可讀性呢。

2. 我們將花費更多的時間來編寫和維護

注釋通常是代碼的第二個版本。當(dāng)我們?yōu)橐粋€函數(shù)寫注釋時我們實際在重復(fù)自己。我們違背了DRY(不要重復(fù)自己)原則。我們正在花費更多的時間且增加了復(fù)雜性。需求如果變了代碼也要跟著變,如果我們寫了注釋也要隨之更改。所以為多花費的一倍時間做出改變吧。我們可以利用這段時間來提高我們的代碼或開發(fā)新的功能。

3. 注釋是不可測試和驗證的

當(dāng)我們修改代碼的時候我們借助諸如編譯器、IDE及單元測試工具來輔助,注釋沒有,沒有類似工具。你無法依靠工具或單元測試來確保它們的使用位置、日期標(biāo)注等是正確的。一旦你寫了一條注釋,因為它是不可測試的無法關(guān)注它的準(zhǔn)確性,一旦出錯便會無法察覺的保留下來。

4. 與代碼相比注釋是不可靠的

通常當(dāng)注釋和代碼脫離它就變得與沒有多大意義了。如果程序員讀到它就可能被誤導(dǎo)。即使沒有誤導(dǎo)也需要通過閱讀源碼來搞清到底做了什么。一個實際的例子,如果我們的老板需要我們做一個修改,我們應(yīng)該看注釋還是代碼呢?當(dāng)然我們會看代碼。

5. 注釋占用了不少屏幕空間

一些注釋方法(像下面的)占了很多行,當(dāng)你想查看更多代碼時這便成了一個問題。

/**

*

* @param title The title of the CD

* @param author The author of the CD

* @param tracks The number of tracks on the CD

* @param durationInMinutes The duration of the CD in minutes

*/

public void addCD(String title, String author,

int tracks, int durationInMinutes) {

CD cd = new CD();

cd.title = title;

cd.author = author;

cd.tracks = tracks;

cd.duration = duration;

cdList.add(cd);

}

更多信息請查看網(wǎng)頁制作
易賢網(wǎng)手機網(wǎng)站地址:網(wǎng)頁重構(gòu)盡量避免使用代碼注釋
由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復(fù)僅供參考,敬請考生以權(quán)威部門公布的正式信息和咨詢?yōu)闇?zhǔn)!

2025國考·省考課程試聽報名

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 加入群交流 | 手機站點 | 投訴建議
工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網(wǎng)安備53010202001879號 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號
云南網(wǎng)警備案專用圖標(biāo)
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號:hfpxwx
咨詢QQ:526150442(9:00—18:00)版權(quán)所有:易賢網(wǎng)
云南網(wǎng)警報警專用圖標(biāo)