回顧一下設(shè)計模式封孙,Spring中使用的設(shè)計模式
設(shè)計模式的六大原則
總原則-開閉原則
對擴展開放欢伏,對修改封閉。在程序需要進行拓展的時候嚣州,不能去修改原有的代碼鲫售,而是要擴展原有代碼,實現(xiàn)一個熱插拔的效果该肴。所以一句話概括就是:為了使程序的擴展性好情竹,易于維護和升級。
1匀哄、單一職責(zé)原則
不要存在多于一個導(dǎo)致類變更的原因秦效,也就是說每個類應(yīng)該實現(xiàn)單一的職責(zé),否則就應(yīng)該把類拆分涎嚼。
2阱州、里氏替換原則(Liskov Substitution Principle)
任何基類可以出現(xiàn)的地方,子類一定可以出現(xiàn)铸抑。里氏替換原則是繼承復(fù)用的基石贡耽,只有當(dāng)衍生類可以替換基類,軟件單位的功能不受到影響時鹊汛,基類才能真正被復(fù)用,而衍生類也能夠在基類的基礎(chǔ)上增加新的行為阱冶。
里氏代換原則是對“開-閉”原則的補充刁憋。實現(xiàn)“開閉”原則的關(guān)鍵步驟就是抽象化。而基類與子類的繼承關(guān)系就是抽象化的具體實現(xiàn)木蹬,所以里氏代換原則是對實現(xiàn)抽象化的具體步驟的規(guī)范至耻。里氏替換原則中,子類對父類的非抽象方法盡量不要重寫和重載。因為父類代表了定義好的結(jié)構(gòu)尘颓,通過這個規(guī)范的接口與外界交互走触,子類不應(yīng)該隨便破壞它。
3疤苹、依賴倒轉(zhuǎn)原則(Dependence Inversion Principle)
面向接口編程互广,依賴于抽象而不依賴于具體。寫代碼時用到具體類時卧土,不與具體類交互惫皱,而與具體類的上層接口交互。
4尤莺、接口隔離原則(Interface Segregation Principle)
每個接口中不存在子類用不到卻必須實現(xiàn)的方法旅敷,如果不然,就要將接口拆分颤霎。使用多個隔離的接口媳谁,比使用單個接口(多個接口方法集合到一個的接口)要好。
5友酱、迪米特法則(最少知道原則)(Demeter Principle)
一個類對自己依賴的類知道的越少越好晴音。無論被依賴的類多么復(fù)雜,都應(yīng)該將邏輯封裝在方法的內(nèi)部粹污,通過public方法提供給外部段多。這樣當(dāng)被依賴的類變化時,才能最小的影響該類壮吩。
最少知道原則的另一個表達(dá)方式是:只與直接的朋友通信进苍。類之間只要有耦合關(guān)系,就叫朋友關(guān)系鸭叙。耦合分為依賴觉啊、關(guān)聯(lián)、聚合沈贝、組合等杠人。我們稱出現(xiàn)為成員變量、方法參數(shù)宋下、方法返回值中的類為直接朋友嗡善。局部變量、臨時變量則不是直接的朋友学歧。我們要求陌生的類不要作為局部變量出現(xiàn)在類中罩引。
6、合成復(fù)用原則(Composite Reuse Principle)
盡量首先使用合成/聚合的方式枝笨,而不是使用繼承袁铐。
23種設(shè)計模式
創(chuàng)建型模式揭蜒。共五種:工廠方法模式、抽象工廠模式剔桨、單例模式屉更、建造者模式、原型模式
結(jié)構(gòu)型模式洒缀。共七種:適配器模式瑰谜、裝飾者模式、代理模式帝洪、外觀模式似舵、橋接模式、組合模式葱峡、享元模式砚哗。
行為型模式。共十一種:策略模式砰奕、模板方法模式蛛芥、觀察者模式、迭代子模式军援、責(zé)任鏈模式仅淑、命令模式、備忘錄模式胸哥、狀態(tài)模式涯竟、訪問者模式、中介者模式空厌、解釋器模式庐船。
設(shè)計模式不止是應(yīng)用與B/S模式也有C/S模式的,有些設(shè)計模式對于B/S幾乎用不上嘲更,也就顯得不常見筐钟。
創(chuàng)建型
1工廠方法模式
AopProxyFactory與DefaultAopProxyFactory
通過工廠方法模式將創(chuàng)建AopProxy的工作從ProxyFactory中分離出來
可以讓調(diào)用方自己選擇工廠
2抽象工廠模式
FactoryBean 接口是基于抽象工廠模式設(shè)計的。Spring 提供了很多這個接口的實現(xiàn)赋朦,比如 ProxyFactoryBean篓冲、JndiFactoryBean、LocalSessionFactoryBean宠哄、LocalContainerEntityManagerFactoryBean 等壹将。
多個工廠產(chǎn)品(方法)時就從工廠方法升級為抽象工廠
3單例模式
嚴(yán)格的沒有,寬泛的容器獲取單例配置bean可以看做單例模式
4建造者模式
BeanDefinitionBuilder
構(gòu)造參數(shù)過多的對象時建議使用
5原型模式
嚴(yán)格的沒有毛嫉,寬泛的容器獲取原型配置bean可以看做原型模式
結(jié)構(gòu)型
6適配器模式
HandlerAdapter通過Handler獲取實際執(zhí)行者瞭恰,適配更具體的執(zhí)行行為
通過適配器轉(zhuǎn)換接口實現(xiàn)
7裝飾者模式
ClientHttpRequestDecorator通過裝飾者模式增強默認(rèn)功能
BeanDefinitionDecorator解析自定義屬性增強Bean定義
8代理模式
AOP中的JdkDynamicAopProxy和CglibAopProxy
裝飾者模式和代理模式的區(qū)別:一個側(cè)重自己能力增強,另一個側(cè)重實現(xiàn)對象的控制狱庇,兩個側(cè)重點不同
9外觀/門面模式
本質(zhì)是:封裝交互惊畏,簡化調(diào)用。
封裝內(nèi)部交互調(diào)用的都可以算外觀模式如定義統(tǒng)一Log接口實現(xiàn)各種日志依賴密任,JdbcUtils封裝連接的操作
10橋接模式
多維度變化時颜启,將其他維度分離出去通過接口引入實現(xiàn),這樣能更好的進行多維度組合浪讳,避免繼承多維度變化產(chǎn)生類爆炸
暫時沒找到橋接的地方缰盏。。淹遵。
11組合模式
解決部分-整體問題口猜。使得用戶對單個對象和組合對象的使用具有一致性,簡單來說封裝復(fù)雜的包含關(guān)系透揣。
暫時沒找到組合模式的地方济炎。。辐真。
12享元模式
共享對象
行為型
13策略模式
AnnotationConfigWebApplicationContext和XmlWebApplicationContext一個基于注解须尚,一個基于xml配置的容器解析
14模板方法模式
AbstractApplicationContext的refresh方法,OncePerRequestFilter的doFilter方法
定義頂層模板侍咱,層層向下放鉤子函數(shù)實現(xiàn)部分邏輯的變化以此實現(xiàn)統(tǒng)一模板邏輯
15觀察者模式
ApplicationEventMulticaster廣播事件被ApplicationListener監(jiān)聽
增加了一定程度的復(fù)雜性耐床,大幅降低耦合,但是異步機制需要自己協(xié)調(diào)順序性
16迭代子模式
封裝集合操作
在Spring中很多集合操作都被封裝到一個完整對象中操作了楔脯,比如HandlerMethodArgumentResolverComposite
17責(zé)任鏈模式
降低耦合撩轰,解決鏈?zhǔn)秸{(diào)用問題
AOP中的ReflectiveMethodInvocation執(zhí)行切面的責(zé)任鏈
18命令模式
解耦命令發(fā)送方和實現(xiàn)方,自然支持撤銷&日志&復(fù)合命令
19備忘錄模式
保存一個對象的某個狀態(tài)昧廷,以便在適當(dāng)?shù)臅r候恢復(fù)對象
20狀態(tài)模式
隨著狀態(tài)的改變堪嫂,許多行為發(fā)生根本的變化,避免狀態(tài)的過多判斷麸粮,可以封裝狀態(tài)類
許多狀態(tài)機的設(shè)計方案
21訪問者模式
通過訪問者模式將目標(biāo)對象的部分行為委托到訪問者進行處理溉苛,適合結(jié)構(gòu)穩(wěn)定,行為多變且和自身關(guān)聯(lián)性不大的類
BeanDefinitionVisitor訪問BeanDefinition設(shè)置屬性弄诲,ClassVisitor通過字節(jié)碼訪問Class對象愚战,此時Class尚未加載
22中介者模式
主要解決對象與對象之間存在大量的關(guān)聯(lián)關(guān)系,將1對多轉(zhuǎn)為1對1(中介)
23解釋器模式
主要用于設(shè)計自定義語法表達(dá)式
SPEL表達(dá)式SpelExpression