遠離程式碼註釋的 5 個理由
免責宣告:我所說的“避免程式碼註釋”並不意味著我不寫註釋,這意味著,我儘可能避免寫程式碼註釋,但當我覺得值得寫時我還是寫的。
“相比寫軟體我們花了更多的時間在閱讀軟體上”,一直以來我沒有見過任何科學研究證明了這一點,但在軟體領域,它就像一個教條或一個共同的信念。由於它的存在,將軟體寫得易於閱讀、關注程式碼的可讀型都是很重要的。通過一些技術的輔助程式設計師可以實現這些要求,這些技術其中之一就是寫程式碼註釋。
當談論起程式碼註釋的時候,有關的辯論總無休止。我們應該用註釋來說明我們程式碼的作用嗎,我們應該將重點放在程式碼的表達性而不需要註釋來輔助閱讀嗎?Joe Kunk為這爭論寫了一篇部落格 - 應不應該寫註釋。有那些人說文件完備的程式碼被認為是好程式碼,還有些人說應該避免註釋,因為註釋通常被用來解釋/隱藏不好的程式碼。
在我看來,在書籍的影響下,為確保程式碼整潔便於重構,我們應該避免寫註釋,除非我們有一個好的寫註釋的理由(例如數學演算法)或因為公司要求或流程我們有義務這樣做。下面是我關於註釋的五點憂慮。
我認為程式碼註釋起到反作用的地方
1.註釋往往鼓勵壞的程式碼。“註釋的程式碼是好程式碼”有這樣一個說法,所以人們常常在程式碼中新增註釋以程式碼漂亮。如果我們為了解釋程式碼而新增註釋這就像是一個訊號:也許我們正在編寫糟糕的程式碼。當我們要寫一條註釋是,我們應該想是否能夠通過清理程式碼使它更有可讀性呢。
2. 我們將花費更多的時間來編寫和維護。註釋通常是程式碼的第二個版本。當我們為一個函式寫註釋時我們實際在重複自己。我們違背了DRY(不要重複自己)原則。我們正在花費更多的時間且增加了複雜性。需求如果變了程式碼也要跟著變,如果我們寫了註釋也要隨之更改。所以為多花費的一倍時間做出改變吧。我們可以利用這段時間來提高我們的程式碼或開發新的功能。
3. 註釋是不可測試和驗證的。當我們修改程式碼的時候我們藉助諸如編譯器、IDE及單元測試工具來輔助,註釋沒有,沒有類似工具。你無法依靠工具或單元測試來確保它們的使用位置、日期標註等是正確的。一旦你寫了一條註釋,因為它是不可測試的無法關注它的準確性,一旦出錯便會無法察覺的保留下來。
4. 與程式碼相比註釋是不可靠的。通常當註釋和程式碼脫離它就變得與沒有多大意義了。如果程式設計師讀到它就可能被誤導。即使沒有誤導也需要通過閱讀原始碼來搞清到底做了什麼。一個實際的例子,如果我們的老闆需要我們做一個修改,我們應該看註釋還是程式碼呢?當然我們會看程式碼。
5. 註釋佔用了不少螢幕空間。一些註釋方法(像下面的)佔了很多行,當你想檢視更多程式碼時這便成了一個問題。
/** * * @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); }
原文地址:http://pauloortins.com/5-reasons-to-avoid-code-comments/
相關文章
- 有趣的程式碼註釋
- 使用 Kubernetes 的 5 個理由
- 使用 button 的 5 個理由
- 程式碼才是最好的註釋
- CSS程式碼註釋CSS
- 請停止程式碼註釋
- 程式設計師是否有義務做好程式碼的註釋?你做好程式碼註釋了嗎?程式設計師
- Oracle PL/SQL程式碼中的註釋OracleSQL
- 程式碼都寫不完,還寫個錘子註釋!
- HTML 程式碼註釋規範HTML
- iOS 註釋方法大全 程式碼塊加快捷鍵註釋iOS
- AI為Spring Boot整個程式碼庫新增了註釋AISpring Boot
- 竟有如此沙雕的程式碼註釋!
- 如何優雅地寫註釋:找到程式碼註釋的黃金平衡點
- jvm執行程式碼註釋部分JVM行程
- 改變Emacs下的註釋程式碼方式以支援當前行(未選中情況下)的註釋/反註釋Mac
- VScode外掛Mintlify Doc智慧生成程式碼註釋,非常離譜!強烈推薦!VSCode
- 如何把程式碼中的註釋批次刪除
- 把Mybatis Generator生成的程式碼加上想要的註釋MyBatis
- 註釋 · 佛祖保佑程式碼永無BUG
- apidoc利用程式碼註釋書寫文件API
- 體面編碼之程式碼註釋評論
- 應該考慮實施 DataOps 的 5 個理由
- 使用Spring的註釋和反射讓程式碼更精簡Spring反射
- IDEA中修改程式碼中的註釋顏色Idea
- 【翻譯】編寫程式碼註釋的最佳實踐
- python程式註釋Python
- PHP程式碼常用註釋規範(PHP Doc)PHP
- 你寫註釋她幫你寫程式碼
- sublime text 多行程式碼註釋快捷鍵行程
- Visual Studio模板程式碼註釋小技巧分享
- 前端程式碼 註釋作者時間與目的前端
- 39個史詩級奇葩程式碼註釋,程式不會崩,但程式設計師會!程式設計師
- 企業整合CRM與ERP系統的5個理由
- Python程式碼註釋的一些基礎知識Python
- IDEA外掛:快速刪除Java程式碼中的註釋IdeaJava
- 程式設計師永遠不要再犯的5個程式設計bug程式設計師
- 用程式碼構建機器心智,我們離這個目標還有多遠?
- VxWorks釋出安全更新修復多個高危遠端程式碼執行漏洞