依賴倒轉(zhuǎn)原則
概念:
A:高層模塊不應(yīng)該依賴地層模塊,兩個(gè)都應(yīng)該依賴抽象.
B:抽象不應(yīng)該依賴細(xì)節(jié),細(xì)節(jié)應(yīng)該依賴于抽象.
C:針對(duì)接口編程,不能針對(duì)實(shí)現(xiàn)編程.
通俗解釋?zhuān)?br>
假設(shè)現(xiàn)在電腦壞了,我們肯定要逐個(gè)排查到底是哪個(gè)地方壞了,然后把壞掉的部分拔掉換成好的,設(shè)想一下假如不能換部件,有一個(gè)地方壞了就得全部換,那是不是一件很蛋疼的事情.而我們的電腦主板在設(shè)計(jì)的時(shí)候就預(yù)留了接口,這就是遵循了依賴倒轉(zhuǎn)原則,我不會(huì)因?yàn)轱L(fēng)扇壞了就去換主板,也不會(huì)因?yàn)橹靼鍓牧巳グ哑渌牧慵Q一個(gè)遍,其實(shí)這些都是一些概念性的東西,說(shuō)起來(lái)簡(jiǎn)單做起來(lái)難,大致大家都明白,但是一到細(xì)節(jié)就懵逼.
里氏代換原則
概念:子類(lèi)必須能夠替換掉他們的父類(lèi)型.
通俗解釋?zhuān)?br>
一個(gè)軟件實(shí)體如果使用的是一個(gè)父類(lèi)的話,那么一定適用于其子類(lèi),而且它察覺(jué)不出父類(lèi)對(duì)象和子類(lèi)對(duì)象的區(qū)別.也就是說(shuō),把父類(lèi)都替換成它的子類(lèi),程序的行為沒(méi)有變化.也正是這個(gè)原則,使得繼承復(fù)用成為了可能,只有當(dāng)子類(lèi)可以替換掉父類(lèi),軟件功能不受影響的時(shí)候,父類(lèi)才能真正被復(fù)用,而子類(lèi)也能在父類(lèi)的基礎(chǔ)上增加新的行為.假如子類(lèi)不做重寫(xiě),那么它調(diào)用父類(lèi)方法的時(shí)候其實(shí)就是多態(tài)的體現(xiàn)(向上轉(zhuǎn)型).
正是由于里氏代換原則,才使得開(kāi)放-封閉原則成為了可能,由于子類(lèi)型的可替換性才使得父類(lèi)類(lèi)型的模塊在無(wú)需修改的情況下就可以拓展,不然還談什么拓展開(kāi)放,修改關(guān)閉呢,再回頭看看依賴倒轉(zhuǎn)原則,高層模塊不應(yīng)該依賴低層模塊,講的不就是繼承嗎,我子類(lèi)不管自己改的再花會(huì)影響到父類(lèi)以及我父類(lèi)的另一個(gè)兒子嗎,顯然是不可能的.
總結(jié):
依賴倒轉(zhuǎn)其實(shí)可以說(shuō)是面向?qū)ο笤O(shè)計(jì)的標(biāo)志,用什么語(yǔ)言來(lái)寫(xiě)程序不重要,如果編寫(xiě)時(shí)考慮的都是如何針對(duì)抽象編程而不是針對(duì)細(xì)節(jié)編程,即程序中的所有的依賴關(guān)系都是終止于抽象類(lèi)或者接口,那就是面向?qū)ο蟮脑O(shè)計(jì),反之那就是過(guò)程化的設(shè)計(jì)了.
后話:
這個(gè)是我一邊看著<<大話設(shè)計(jì)模式>>一邊理解總結(jié)加摘抄寫(xiě)的筆記,但愿自己沒(méi)事兒回頭了還能看看感慨一下,哈哈!!!