讀C#代碼整潔之道筆記01_C#的編碼標準和原則

来源:https://www.cnblogs.com/lying7/archive/2023/03/20/17232202.html
-Advertisement-
Play Games

1. 編碼原則 1.1. SOLID原則 1.1.1. 單一職責原則(Single Respon-sibility Principle) 1.1.1.1. 類和方法應當僅具備單一職責。所有組合為單一職責的元素應當組合在一起併進行封裝。 1.1.2. 開閉原則(Open-Closed Principl ...


1. 編碼原則

1.1. SOLID原則

  • 1.1.1. 單一職責原則(Single Respon-sibility Principle)

  • 1.1.1.1. 類和方法應當僅具備單一職責。所有組合為單一職責的元素應當組合在一起併進行封裝。

  • 1.1.2. 開閉原則(Open-Closed Principle)

  • 1.1.2.1. 類和方法應當對擴展開放,對修改封閉。

  • 1.1.3. 里氏替換原則(Liskov Substitution)

  • 1.1.3.1. 若函數接收一個基類的指針,那麼該指針應當可以替換為任何從基類派生的類(的指針)而無須事先知曉具體類信息。

  • 1.1.4. 介面隔離原則(Interface Segregation Principle)

  • 1.1.4.1. 與其設計一個大而全的介面不如拆分為若幹小型介面,而類可以選擇實現需要的介面中的方法。

  • 1.1.5. 依賴倒置原則(Dependency Inversion Principle)

  • 1.1.5.1. 高層次的模塊不應當依賴低層次的模塊。

  • 1.1.5.2. 低層次的模塊的替換不應當影響高層次模塊的使用。

  • 1.1.5.3. 不論是高層次的模塊還是低層次的模塊都應當依賴於抽象。

  • 1.1.5.4. 抽象不應當依賴於細節,但是細節應當依賴於抽象。

1.2. YAGNI原則

  • 1.2.1. “你不會需要它”(You Ain't Gonna Need It)

  • 1.2.2. 確保類、方法和整體代碼行數保持絕對最小水平。

1.3. KISS原則

  • 1.3.1. “保持軟體簡單易懂”(Keep It Simple,Stupid)

  • 1.3.2. 務必要保持代碼整潔易讀,確保即使是新手程式員也能夠理解其含義。

1.4. DRY原則

  • 1.4.1. “避免重覆的代碼”(Don't Repeat Yourself)

  • 1.4.2. 當遇到重覆代碼時應當儘早將其移除

1.5. 奧卡姆剃刀法則

  • 1.5.1. Occam's Razor, Ockham's Razor

  • 1.5.2. “如無必要,勿增實體”,即“簡單有效原理”。

  • 1.5.2.1. 最簡單的方案也最可能是正確的那個方案

  • 1.5.2.2. 假設越多,設計方案包含缺陷的可能性就越大

  • 1.5.2.3. 項目的構成組件越少,出問題的可能性就越少

2. 編碼方法

2.1. 測試驅動開發(Test-Driven Development,TDD)

2.2. 行為驅動開發(Behavioral-Driven Development,BDD)

  • 2.2.1. SpecFlow

2.3. 面向方面編程(Aspect-Oriented Programming,AOP)

  • 2.3.1. PostSharp

3. 良好代碼

3.1. 合理的縮進

  • 3.1.1. 工具實現

3.2. 有意義的註釋

3.3. API文檔註釋

  • 3.3.1. 文檔越易用,開發人員使用API的意願就越強

3.4. 使用命名空間合理組織代碼

  • 3.4.1. 使用命名空間合理組織代碼

3.5. 合理的命名規則

  • 3.5.1. Pascal命名法

  • 3.5.1.1. 命名空間、類、介面、枚舉和方法

  • 3.5.2. 駝峰命名法

  • 3.5.2.1. 變數名稱、參數名稱

  • 3.5.3. 在成員變數上必須加上首碼下劃線

3.6. 一個類執行一種任務

3.7. 一個方法做一件事情

3.8. 方法的代碼少於10行,最好不超過4行

  • 3.8.1. 代碼格式化、鏈式函數算1行?

3.9. 方法的參數不多於兩個

  • 3.9.1. 方法最好沒有參數

  • 3.9.2. 有兩個以上的參數時就需要考慮類和方法的職責是不是太多了

  • 3.9.3. 方法的確需要兩個以上的參數,那麼最好將其合併為一個對象參數

3.10. 合理使用異常

3.11. 代碼可讀性強

3.12. 代碼耦合程度低

3.13. 高內聚的代碼

  • 3.13.1. 將公共的功能正確地分組的代碼具有高度的內聚性

3.14. 對象會被恰當銷毀

  • 3.14.1. 請務必調用Dispose()方法明確地銷毀使用中的資源

  • 3.14.2. 將對象(引用)設置為null以使其超出作用範圍

  • 3.14.3. using語句

3.15. 避免使用Finalize()方法

  • 3.15.1. 最好在更加可靠的Dispose()方法中來銷毀非托管資源

3.16. 合理地進行抽象

  • 3.16.1. 當設計只向更高的級別開放,並僅開放必需的內容時,它就處在正確的抽象層次上

3.17. 在大型類中使用#region進行區域劃分


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 教程簡介 IT寶庫MS項目入門教程 - 從基本概念開始,簡單易學地學習MS項目,包括設置,簡介,入門,創建新計劃,設置資源,為任務分配資源,計劃持續時間成本和時間,跟蹤進度,高級計劃,項目狀態報告。 Microsoft Project 是一個國際上享有盛譽的通用的項目管理工具軟體,凝集了許多成熟的項 ...
  • 本文已收錄至Github,推薦閱讀 👉 Java隨想錄 微信公眾號:Java隨想錄 摘要 空指針異常(NullPointerException)可以說是Java程式員最容易遇到的問題了,影響說大不大,說小也不小。為瞭解決這個問題,Java 8 版本中推出了 Optional 類。Optional ...
  • _pycache__文件夾可以看作該文件夾下文件已被python接管或者說編譯過。 在第一次執行代碼的時候,Python解釋器已經把編譯的位元組碼放在__pycache__文件夾中,這樣以後再次運行的話,如果被調用的模塊未發生改變,那就直接跳過編譯這一步,直接去__pycache__文件夾中去運行相關 ...
  • 目前由於功能比較簡單,沒有進行前後端拆分,主要技術點:SpringBoot、WebSocket、webjars、Vue、Element-UI、axios、jszip,核心壓縮庫是 Thumbnailator 提供壓縮支持。源代碼已經在 碼雲 star 公開。歡迎各位大佬批評。 ...
  • 解讀 Servlet 源碼:GenericServlet,ServletConfig,ServletContext 每博一文案 人活著,就得隨時準備經受磨難。他已經看過一些書,知道不論是普通人還是了不起的人,都要在自己的一生中經歷許多磨難。磨難使人堅強。 人和社會、一切鬥爭的總結局也許都是中庸而已。 ...
  • 在剛接觸後臺線程的時候,覺得線程神秘且高深,並且時常有先輩們千叮萬囑:能不用的時候,儘量不要用,千萬不要濫用線程,否則會發生預料不到的結果。在接觸線程一段時間後,感覺線程也不過如此,輕而易舉的就可以創建,所以逐漸大膽起來,項目里隨處可見的都是Task,Thread,async,await等內容。在大... ...
  • 一周一周來算,註,如果本月1號是星期日,則這一月共有六周,即六行,所以乾脆每月都輸出6周就行了,然後再算第一周里的本月一號是周幾,第一周里本月又占了幾天。。。呃。。。反正很亂,想了一上午,現在寫出來了倒不知道如何解釋了。。算了。。直接上代碼。。 //日曆界面 public IActionResult ...
  • 調用Win32 API(優先順序最高,全局監聽, 支持最小化失焦等情況) 那麼,假如我要在一個WPF程式監聽CTRL+5按鍵,首先在主視窗程式添加以下代碼: /// <summary> /// CTRL+5事件Id /// </summary> private const int Ctrl5KeyEv ...
一周排行
    -Advertisement-
    Play Games
  • GoF之工廠模式 @目錄GoF之工廠模式每博一文案1. 簡單說明“23種設計模式”1.2 介紹工廠模式的三種形態1.3 簡單工廠模式(靜態工廠模式)1.3.1 簡單工廠模式的優缺點:1.4 工廠方法模式1.4.1 工廠方法模式的優缺點:1.5 抽象工廠模式1.6 抽象工廠模式的優缺點:2. 總結:3 ...
  • 新改進提供的Taurus Rpc 功能,可以簡化微服務間的調用,同時可以不用再手動輸出模塊名稱,或調用路徑,包括負載均衡,這一切,由框架實現並提供了。新的Taurus Rpc 功能,將使得服務間的調用,更加輕鬆、簡約、高效。 ...
  • 本章將和大家分享ES的數據同步方案和ES集群相關知識。廢話不多說,下麵我們直接進入主題。 一、ES數據同步 1、數據同步問題 Elasticsearch中的酒店數據來自於mysql資料庫,因此mysql數據發生改變時,Elasticsearch也必須跟著改變,這個就是Elasticsearch與my ...
  • 引言 在我們之前的文章中介紹過使用Bogus生成模擬測試數據,今天來講解一下功能更加強大自動生成測試數據的工具的庫"AutoFixture"。 什麼是AutoFixture? AutoFixture 是一個針對 .NET 的開源庫,旨在最大程度地減少單元測試中的“安排(Arrange)”階段,以提高 ...
  • 經過前面幾個部分學習,相信學過的同學已經能夠掌握 .NET Emit 這種中間語言,並能使得它來編寫一些應用,以提高程式的性能。隨著 IL 指令篇的結束,本系列也已經接近尾聲,在這接近結束的最後,會提供幾個可供直接使用的示例,以供大伙分析或使用在項目中。 ...
  • 當從不同來源導入Excel數據時,可能存在重覆的記錄。為了確保數據的準確性,通常需要刪除這些重覆的行。手動查找並刪除可能會非常耗費時間,而通過編程腳本則可以實現在短時間內處理大量數據。本文將提供一個使用C# 快速查找並刪除Excel重覆項的免費解決方案。 以下是實現步驟: 1. 首先安裝免費.NET ...
  • C++ 異常處理 C++ 異常處理機制允許程式在運行時處理錯誤或意外情況。它提供了捕獲和處理錯誤的一種結構化方式,使程式更加健壯和可靠。 異常處理的基本概念: 異常: 程式在運行時發生的錯誤或意外情況。 拋出異常: 使用 throw 關鍵字將異常傳遞給調用堆棧。 捕獲異常: 使用 try-catch ...
  • 優秀且經驗豐富的Java開發人員的特征之一是對API的廣泛瞭解,包括JDK和第三方庫。 我花了很多時間來學習API,尤其是在閱讀了Effective Java 3rd Edition之後 ,Joshua Bloch建議在Java 3rd Edition中使用現有的API進行開發,而不是為常見的東西編 ...
  • 框架 · 使用laravel框架,原因:tp的框架路由和orm沒有laravel好用 · 使用強制路由,方便介面多時,分多版本,分文件夾等操作 介面 · 介面開發註意欄位類型,欄位是int,查詢成功失敗都要返回int(對接java等強類型語言方便) · 查詢介面用GET、其他用POST 代碼 · 所 ...
  • 正文 下午找企業的人去鎮上做貸後。 車上聽同事跟那個司機對罵,火星子都快出來了。司機跟那同事更熟一些,連我在內一共就三個人,同事那一手指桑罵槐給我都聽愣了。司機也是老社會人了,馬上聽出來了,為那個無辜的企業經辦人辯護,實際上是為自己辯護。 “這個事情你不能怪企業。”“但他們總不能讓銀行的人全權負責, ...