以前一直認(rèn)為程序中的類有使用到封裝繼承多態(tài)就是面向?qū)ο笤O(shè)計(jì)捐川,其實(shí)不然。
封裝逸尖、繼承古沥、多態(tài)只是面向?qū)ο蟮娜筇匦裕窃谠O(shè)計(jì)程序的時(shí)候并不是說類的結(jié)構(gòu)使用到了(或是體現(xiàn)出了)這三個(gè)特性就是面向?qū)ο螅?/b>其實(shí)真正的面向?qū)ο笤O(shè)計(jì)是要符合下面的五大原則:
單一職責(zé)原則(SRP)
開放封閉原則(OCP)
里氏替換原則(LSP)
依賴倒置原則(DIP)
接口隔離原則(ISP)
單一職責(zé)原則(SRP)
?????? 一個(gè)類應(yīng)該僅有一個(gè)引起它變化的原因(最簡單娇跟,最容易理解卻最不容易做到的一個(gè)設(shè)計(jì)原則)
職員類例子:
比如在職員類里岩齿,將工程師、銷售人員苞俘、銷售經(jīng)理這些情況都放在職員類里考慮盹沈,其結(jié)果將會(huì)非常混亂吃谣,在這個(gè)假設(shè)下乞封,職員類里的每個(gè)方法都要if else判斷是哪種情況,從類結(jié)構(gòu)上來說將會(huì)十分臃腫岗憋,并且上述三種的職員類型肃晚,不論哪一種發(fā)生需求變化,都會(huì)改變職員類仔戈!這個(gè)是大家所不愿意看到的关串!
開放封閉原則(OCP)
?????? 既開放又封閉拧廊,對(duì)擴(kuò)展是開放的,對(duì)更改是封閉的晋修!
?????? 擴(kuò)展即擴(kuò)展現(xiàn)行的模塊吧碾,當(dāng)我們軟件的實(shí)際應(yīng)用發(fā)生改變時(shí),出現(xiàn)新的需求飞蚓,就需要我們對(duì)模塊進(jìn)行擴(kuò)展滤港,使其能夠滿足新的需求!
更改封閉即是在我們對(duì)模塊進(jìn)行擴(kuò)展時(shí)趴拧,勿需對(duì)源有程序代碼和DLL進(jìn)行修改或重新編譯文件溅漾!
這個(gè)原則對(duì)我們?cè)谠O(shè)計(jì)類的時(shí)候很有幫助,堅(jiān)持這個(gè)原則就必須盡量考慮接口封裝著榴,抽象機(jī)制和多態(tài)技術(shù)添履!
里氏替換原則(LSP)
?????? 子類可以替換父類并且出現(xiàn)在父類能夠出現(xiàn)的任何地方
?????? 這個(gè)原則也是在貫徹GOF倡導(dǎo)的面向接口編程!
在這個(gè)原則中父類應(yīng)盡可能使用接口或者抽象類來實(shí)現(xiàn)脑又!
子類通過實(shí)現(xiàn)了父類接口暮胧,能夠替父類的使用地方!
通過這個(gè)原則问麸,我們客戶端在使用父類接口的時(shí)候往衷,通過子類實(shí)現(xiàn)!
意思就是說我們依賴父類接口严卖,在客戶端聲明一個(gè)父類接口席舍,通過其子類來實(shí)現(xiàn)
這個(gè)時(shí)候就要求子類必須能夠替換父類所出現(xiàn)的任何地方,這樣做的好處就是哮笆,在根據(jù)新要求擴(kuò)展父類接口的新子類的時(shí)候而不影響當(dāng)前客戶端的使用来颤!
依賴倒置原則(DIP)
?????? 傳統(tǒng)的結(jié)構(gòu)化編程中,最上層的模塊通常都要依賴下面的子模塊來實(shí)現(xiàn)稠肘,也
稱為高層依賴低層福铅!
所以DIP原則就是要逆轉(zhuǎn)這種依賴關(guān)系,讓高層模塊不要依賴低層模塊项阴,所以稱之為依賴倒置原則滑黔!
接口隔離原則(ISP)
?????? 這個(gè)原則的意思是:使用多個(gè)專門的接口比使用單個(gè)接口要好的多!
這個(gè)我有體會(huì)环揽,在我實(shí)際編程中拷沸,為了減少接口的定義,將許多類似的方法都放在一個(gè)接口中薯演,最后發(fā)現(xiàn)撞芍,維護(hù)和實(shí)現(xiàn)接口的時(shí)候花了太多精力,而接口所定義的操作相當(dāng)于對(duì)客戶端的一種承諾跨扮,這種承諾當(dāng)然是越少越好序无,越精練越好验毡,過多的承諾帶來的就是你的大量精力和時(shí)間去維護(hù)!