面向對象七大設計原則(轉)

来源:http://www.cnblogs.com/chuangege/archive/2016/09/02/5832269.html
-Advertisement-
Play Games

一、單一職責原則: 全稱:“Single-Responsibility Principle” 面向對象設計 說明:就一個類而言,應該只專註於做一件事和僅有一個引起它變化的原因。所謂職責,我們可以理解他為功能,就是設計的這個類功能應該只有一個,而不是兩個或更多。也可以理解為引用變化的原因,當你發現有兩 ...


一、單一職責原則:

全稱:“Single-Responsibility Principle”

面向對象設計

說明:就一個類而言,應該只專註於做一件事和僅有一個引起它變化的原因。所謂職責,我們可以理解他為功能,就是設計的這個類功能應該只有一個,而不是兩個或更多。也可以理解為引用變化的原因,當你發現有兩個變化會要求我們修改這個類,那麼你就要考慮撤分這個類了。因為職責是變化的一個軸線,當需求變化時,該變化會反映類的職責的變化。

使用SRP註意點:

1、一個合理的類,應該僅有一個引起它變化的原因,即單一職責;

2、在沒有變化徵兆的情況下應用SRP或其他原則是不明智的;

3、在需求實際發生變化時就應該應用SRP等原則來重構代碼;

4、使用測試驅動開發會迫使我們在設計出現臭味之前分離不合理代碼;

5、如果測試不能迫使職責分離,僵化性和脆弱性的臭味會變得很強烈,那就應該用Facade或Proxy模式對代碼重構;SRP優點:消除耦合,減小因需求變化引起代碼僵化。

二、里氏代換原則

全稱:“Liskov Substitution Principle”

說明:子類型必須能夠替換它們的基類型。一個軟體實體如果使用的是一個基類,那麼當把這個基類替換成繼承該基類的子類,程式的行為不會發生任何變化。軟體實體察覺不出基類對象和子類對象的區別。

優點:可以很容易的實現同一父類下各個子類的互換,而客戶端可以毫不察覺。

三、依賴倒置原則

全稱:“Dependence Inversion Principle”

說明:要依賴於抽象,不要依賴於具體。客戶端依賴於抽象耦合。

抽象不應當依賴於細節;細節應當依賴於抽象;

要針對介面編程,不針對實現編程。

優點:使用傳統過程化程式設計所創建的依賴關係,策略依賴於細節,這是糟糕的,因為策略受到細節改變的影響。依賴倒置原則使細節和策略都依賴於抽象,抽象的穩定性決定了系統的穩定性。

怎樣做到依賴倒置?

以抽象方式耦合是依賴倒轉原則的關鍵。抽象耦合關係總要涉及具體類從抽象類繼承,並且需要保證在任何引用到基類的地方都可以改換成其子類,因此,里氏代換原則是依賴倒轉原則的基礎。

在抽象層次上的耦合雖然有靈活性,但也帶來了額外的複雜性,如果一個具體類發生變化的可能性非常小,那麼抽象耦合能發揮的好處便十分有限,這時可以用具體耦合反而會更好。

層次化:所有結構良好的面向對象構架都具有清晰的層次定義,每個層次通過一個定義良好的、受控的介面向外提供一組內聚的服務。

依賴於抽象:建議不依賴於具體類,即程式中所有的依賴關係都應該終止於抽象類或者介面。儘量做到:

1、任何變數都不應該持有一個指向具體類的指針或者引用。

2、任何類都不應該從具體類派生。

3、任何方法都不應該覆寫它的任何基類中的已經實現的方法。

四、介面隔離原則

全稱:“Interface Segregation Principle”

說明:使用多個專一功能的介面比使用一個的總介面總要好。從一個客戶類的角度來講:一個類對另外一個類的依賴性應當是建立在最小介面上的。過於臃腫的介面是對介面的污染,不應該強迫客戶依賴於它們不用的方法。

優點:會使一個軟體系統功能擴展時,修改的壓力不會傳到別的對象那裡。

如何實現介面隔離原則

不應該強迫用戶依賴於他們不用的方法。

1、利用委托分離介面。

2、利用多繼承分離介面。

五、迪米特原則

全稱:“Law of Demeter”

說明:對象與對象之間應該使用儘可能少的方法來關聯,避免千絲萬縷的關係。

如何實現迪米特法則?

迪米特法則的主要用意是控制信息的過載,在將其運用到系統設計中應註意以下幾點:

1) 在類的劃分上,應當創建有弱耦合的類。類之間的耦合越弱,就越有利於復用。

2) 在類的結構設計上,每一個類都應當儘量降低成員的訪問許可權。一個類不應當public自己的屬性,而應當提供取值和賦值的方法讓外界間接訪問自己的屬性。

3) 在類的設計上,只要有可能,一個類應當設計成不變類。

4) 在對其它對象的引用上,一個類對其它對象的引用應該降到最低。

六、開放-封閉原則

全稱:“Open-Closed Principle”

說明:對擴展開放,對修改關閉。

優點:按照OCP原則設計出來的系統,降低了程式各部分之間的耦合性,其適應性、靈活性、穩定性都比較好。當已有軟體系統需要增加新的功能時,不需要對作為系統基礎的抽象層進行修改,只需要在原有基礎上附加新的模塊就能實現所需要添加的功能。增加的新模塊對原有的模塊完全沒有影響或影響很小,這樣就無須為原有模塊進行重新測試。

如何實現“開-閉”原則?

在面向對象設計中,不允許更改的是系統的抽象層,而允許擴展的是系統的實現層。換言之,定義一個一勞永逸的抽象設計層,允許儘可能多的行為在實現層被實現。

解決問題關鍵在於抽象化,抽象化是面向對象設計的第一個核心本質。

對一個事物抽象化,實質上是在概括歸納總結它的本質。抽象讓我們抓住最最重要的東西,從更高一層去思考。這降低了思考的複雜度,我們不用同時考慮那麼多的東西。換言之,我們封裝了事物的本質,看不到任何細節。

在面向對象編程中,通過抽象類及介面,規定了具體類的特征作為抽象層,相對穩定,不需更改,從而滿足“對修改關閉”;而從抽象類導出的具體類可以改變系統的行為,從而滿足“對擴展開放”。

對實體進行擴展時,不必改動軟體的源代碼或者二進位代碼。關鍵在於抽象。

七,合成複原原則:

全稱:(Composite Reuse Principle,CRP)

      儘量使用對象組合,而不是繼承來達到復用的目的。

 組合/聚合復用原則(Composite/Aggregate Reuse Principle CARP).組合和聚合都是對象建模中關聯(Association)關係的一種.聚合表示整體與部分的關係,表示“含有”,整體由部分組合而成,部分可以脫離整體作為一個獨立的個體存在。組合則是一種更強的聚合,部分組成整體,而且不可分割,部分不能脫離整體而單獨存在。在合成關係中,部分和整體的生命周期一樣,組合的新的對象完全支配其組成部分,包括他們的創建和銷毀。一個合成關係中成分對象是不能與另外一個合成關係共用。

      組合/聚合和繼承是實現復用的兩個基本途徑。合成復用原則是指儘量使用合成/聚合,而不是使用繼承。

       只有當以下的條件全部被滿足時,才應當使用繼承關係。

         1. 子類是超類的一個特殊種類,而不是超類的一個角色,也就是區分“Has-A”和“Is-A”.只有“Is-A”關係才符合繼承關係,“Has-A”關係應當使用聚合來描述。

         2 .永遠不會出現需要將子類換成另外一個類的子類的情況。如果不能肯定將來是否會變成另外一個子類的話,就不要使用繼承。

         3 .子類具有擴展超類的責任,而不是具有置換掉或註銷掉超類的責任。如果一個子類需要大量的置換掉超類的行為,那麼這個類就不應該是這個超類的子類。

     錯誤的使用繼承而不是合成/聚合的一個常見原因是錯誤地把“Has-A”當成了“Is-A”.”Is-A”代表一個類是另外一個類的一種;而“Has-A”代表一個類是另外一個類的一個角色,而不是另外一個類的特殊種類。


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

-Advertisement-
Play Games
更多相關文章
  • 第一次在博客園發表文章,不多說,先上系統截圖。此系統是自己全程參與項目過程,從前期的技術方案整理到整個項目驗收,具體功能代碼實現,後續發表。 1、登錄: 2、客戶端主頁面 3、系統-切換機組伺服器 4、系統-配置伺服器 5、系統-數據下載 6、系統-更換皮膚 7、基礎數據-承包商檢驗人員 8、基礎數 ...
  • 字元串必須是數字,不要超過轉換成目標數字類型的範圍。超過的話系統也會報錯(溢出)。 static void Main(string[] args) { string s; int i; Console.WriteLine("please enter a number"); s = Console.R ...
  • 系統代碼是平臺內置的、通用的、統一的數據描述。代碼管理(數據字典)是整個平臺中數據描述的有效機制。通過界面進行可視化的操作和維護,能快速錄入和修改平臺上統一的字典數據。有效提高了數據的重覆利用率和產品、項目的開發效率。整個數據字典數據為框架平臺所共用,用戶可以更好地對系統進行自定義管理,以滿足自己的... ...
  • 一、項目背景: 最近,做項目,因為是金融項目,客戶登錄交易的時候,有一個提示框,就是告知客戶要“入市需謹慎”等等,想必大家都遇到這樣的場景,當然,這種提示是沒人會看的,不過作為交易所,這樣的提示又必不可少的。 其實只有一個要求: 必須客戶讀完“確定”按鈕和CheckBox才會生效 客戶只要把滾動條拉 ...
  • 刪除引用中的該dll,重新引用選擇解決方案下的項目引用,下次F12就不會進入到元數據而是進入到源代碼中方便調試 ...
  • 近來一直翻閱國內網站,發現擴展欄位的時候僅僅做到了可以註冊時候添加,並修改資料庫,但是後續的操作就沒有了,那麼列如我添加了昵稱欄位,怎麼顯示呢?不知是不是因為我剛入門的原因,一直沒有找不到方法,最後再國外論壇找到了方法。核心為下麵4句話,簡單記錄,晚上後續展開修改 指路地址 https://blog ...
  • 1. 利用“命名實參”,您將能夠為特定形參指定實參,方法是將實參與該形參的名稱關聯,而不是與形參在形參列表中的位置關聯。 static void Main(string[] args) { Console.WriteLine(CalculateBMI(weight: 123, height: 64) ...
  • 上一篇博文中我們快速的介紹了dapper的一些基本CURD操作,也是我們manipulate db不可或缺的最小單元,這一篇我們介紹下相對複雜 一點的操作,源碼分析暫時就不在這裡介紹了。 一:table sql 為了方便,這裡我們生成兩個表,一個Users,一個Product,sql如下: <1> ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...