1. 程式人生 > >【設計原則】面向物件程式設計的六大原則

【設計原則】面向物件程式設計的六大原則

參考文章:

一、單一職責原則:

全稱:Single-Responsibility Principle

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

使用SRP注意點

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

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

3、在需求實際發生變化時就應該應用SRP

等原則來重構程式碼;

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

5、如果測試不能迫使職責分離,僵化性和脆弱性的臭味會變得很強烈,那就應該用FacadeProxy模式對程式碼重構;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原則設計出來的系統,降低了程式各部分之間的耦合性,其適應性、靈活性、穩定性都比較好。當已有軟體系統需要增加新的功能時,不需要對作為系統基礎的抽象層進行修改,只需要在原有基礎上附加新的模組就能實現所需要新增的功能。增加的新模組對原有的模組完全沒有影響或影響很小,這樣就無須為原有模組進行重新測試。

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

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

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

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

在面向物件程式設計中,通過抽象類及介面,規定了具體類的特徵作為抽象層,相對穩定,不需更改,從而滿足“對修改關閉”;而從抽象類匯出的具體類可以改變系統的行為,從而滿足“對擴充套件開放”。

對實體進行擴充套件時,不必改動軟體的原始碼或者二進位制程式碼。關鍵在於抽象。

相關推薦

設計原則面向物件程式設計六大原則

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

設計模式面向物件六大原則

主要內容 關於面向物件六大原則 單一職責原則(Single Responsibility Principle) 縮寫為SRP。 對於一個類而言,應該僅有一個引起它變化的原因。或者說一個類中應該是一組相關性很高的函式、資料的封裝。大意就是一個類應該只做一件事情,這就是職

Java-3面向物件程式設計理解

面向物件程式設計核心在於“封裝”,即將同一類事物抽象為類class,類似於關係資料庫中實體型,這個類中元素就如屬性一般去描述這個類,“屬性”不僅包括變數,還包括這個類可能使用的函式,也叫方法,由變數和函式即可構成一個類。同時這個“類”的概念也可以類比於C語言中結構體型別,只不過相比於結構體,“類”中

python基礎面向物件程式設計(初級篇)

在Python教學中發現,很多同學在走到面向物件程式設計這塊就開始蒙圈了,為了幫助大家更好的理解面向物件程式設計並其能將其用到自己的開發過程中,特寫此文。 概述 面向過程:根據業務邏輯從上到下寫壘程式碼 函式式:將某功能程式碼封裝到函式中,日後便無需重複

設計模式面向物件小結——重寫與過載

     通過對《大話設計模式》附錄的學習,讓我對面向物件技術有了更深一層的理解!下面是我畫的一張導圖,是我對面向物件技術的總體概括。這篇文章的主要內容,就是圍繞這張圖,來講述我的理解。。    

面向物件程式設計六大原則總結

內聚性描述了一個例程內部組成部分之間相互聯絡的緊密程度。 耦合性描述了一個例程與其他例程之間聯絡的緊密程度。 軟體開發的目標應該是建立這樣的例程:內部完整,而與其他例程之間的聯絡小巧,直接,可見,靈活,即高內聚,鬆耦合。 原文http://blog.csdn.net/ro

Android設計模式學習筆記|一|面向物件六大原則

單一職責原則、開閉原則、里氏替換原則、依賴倒置原則、介面隔離原則、迪米特原則。 一、單一職責原則(Single Responsibility Principle SRP) 定義:就一個類而言,應該就有一個引起它變化的原因。簡單來說,一個類中應該是一組相關性很高的函式、資料

java面向物件程式設計——類與物件的繼承和多型

一、程式碼塊 程式碼塊定義:使用 {} 定義的一段程式碼。 根據程式碼塊定義的位置以及關鍵字,又可分為以下四種: 普通程式碼塊(定義在方法中,除錯) 構造塊(定義在類中的(不加修飾符)) 靜態塊 同步程式碼塊 構造塊 構造塊在每次產生一個新的物件就呼叫一次構

java面向物件程式設計——類與物件的封裝

Java比C更方便的地方在於Java是面向物件的。面向物件的特徵: 1、封裝 ; 2、繼承 ; 3、多型; 以下對面向物件的封裝特徵進行簡述: 一、類與物件的定義與使用 類是指共性的概念,物件是一個具體的、可以使用的事物。 首先產生類,而後才可以產生物件。 類的組成: 1.

讀Android原始碼設計模式解析與實戰(第一章面向物件六大原則

    買了很多書,也看了很多,但有一個毛病就是看的時候很明白,但是看過不久就忘了,可見溫故而知新是很重要的,所以想重拾上學時的習慣,記筆記好了,經常來看看,記錄下看的時候的心得、體會。鼓勵自己堅持下去     OOP在java中很重要,提到OOP就會想到面向物件的六大原則

含有預設引數的函式面向物件程式設計上機練習三(有預設引數的函式)

Think: 1、學習理解: (1):若在定義時而不是在宣告時置預設值,那麼函式定義一定要在函式的呼叫之前 (2):不能將實際值傳遞給引用型別的引數。可以將變數作引用型別引數的預設值,這時變數必須是已經宣告且是全域性變數。 (3):若給某一引數設定了預設

Java基礎筆記整理---07面向物件程式設計-類和物件

int 型別預設值為 0 String型別預設值為null 方法(函式):返回值 方法名(引數型別 引數名稱, ...){方法體(程式碼塊)}this指呼叫的方法中(當前)的變數類與物件1.構造方法:1> 構造物件 構造例項的方法,一個特殊方法,方法名需要與類名相同,

設計模式(一)面向物件六大原則

買 設計模式 這本書已經快半年了,看著嶄新的書,心裡還有很愧疚的,趁著過年,沒啥開發任務。就把最近零零碎碎的知識總結下。 面向物件的六大原則,一些在平常開發中,跟著老大的風格寫程式碼,無意識中肯定遵守了一些原則,只是意識中知道這樣寫程式碼很有調理。具體為什麼,不太清楚。

CPP基礎面向物件程式設計思想 + 輸入和輸出相關(一)

引自高翔博士的《視覺SLAM十四將》: 用著用著才發現C++和Linux才是我的真愛。 開始做人工智慧和人工智慧相關的人和團體越來越多,雖然初期學習中會發現對於絕大多數沒有什麼程式設計基礎的人來說Python是一個非常便於上手的語言,而且甚多開源構架都有基於Pytho

PHP篇面向物件基礎

1、宣告:class 類名{                          //成員屬性(變數) 修飾符 $變數名=初值;       &nb

ABP雜燴面向切面程式設計(AOP)知識總結

目錄 1.存在問題 2.AOP的概念 3.AOP應用範圍 3.AOP實現方式 4.應用舉例 5.結束語 本文在學習【老張的哲學】系列文章AOP相關章節後,自己歸納總結的筆記。 1.存在問題 最近,其它專案小組在開發的過程中遇到了一個問題,在日誌記錄時,使用者明明點選的是更新操作,可翻看記

6.3 SAP ABAP 開放封閉原則(OCP)- 摘自 《SAP ABAP面向物件程式設計原則、模式及實踐》 6.3 SAP ABAP 開放封閉原則(OCP)- 摘自 《SAP ABAP面向物件程式設計原則、模式及實踐》

6.3 SAP ABAP 開放封閉原則(OCP)- 摘自 《SAP ABAP面向物件程式設計:原則、模式及實踐》   6.3 開放封閉原則(OCP) 開閉原則(Open-Closed Principle, OCP)指的是,一個類或者模組,如果在業務修改或者功能需要擴充套

軟考——面向物件技術(1)

面向物件???——》一種具有構造繼承性、 封裝性和多型的程式設計語言族的命名;               ???——》一種程式設計風格; 面向物件???——》物件 + 分類 + 繼承 + 

軟考——面向物件技術(3)

物件圖???——》展現了某一時刻一組物件以及它們之間的關係;描述了在類圖中所建立的事物的例項的靜態快照; 建立系統的靜態設計檢視或靜態程序檢視???——》使用物件圖對物件結構進行建模;???——》從

2018-09-17面向物件六大原則

在使用面向物件思想進行程式設計開發過程中,有六大原則需要注意,六大原則在面向物件程式設計中是作為程式設計的“指導思想”和行動指南存在的 六大原則如下: 1.單一職責原則;2.開閉原則;3.里氏轉換原則; 4.依賴倒置原則;5.介面隔離原則;6迪米特原則; 一.里氏