一. 簡單工廠
又叫作靜態工廠方法(StaticFactory Method)模式,但不屬於23種GOF設計模式之一。算法
簡單工廠模式的實質是由一個工廠類根據傳入的參數,動態決定應該建立哪個產品類。數據庫
Spring中的BeanFactory就是簡單工廠模式的體現,根據傳入一個惟一的標識來得到Bean對象,可是否是在傳入參數後建立仍是傳入參數前建立這個要根據具體狀況來定。設計模式
二. 工廠方法(Factory Method)
定義一個用於建立對象的接口,讓子類決定實例化哪個類。Factory Method使一個類的實例化延遲到其子類。架構
Spring中的FactoryBean就是典型的工廠方法模式。以下圖:app
三. 單例(Singleton)
保證一個類僅有一個實例,並提供一個訪問它的全局訪問點。學習
Spring中的單例模式完成了後半句話,即提供了全局的訪問點BeanFactory。但沒有從構造器級別去控制單例,這是由於Spring管理的是是任意的Java對象。spa
四. 適配器(Adapter)
將一個類的接口轉換成客戶但願的另一個接口。Adapter模式使得本來因爲接口不兼容而不能一塊兒工做的那些類能夠一塊兒工做。設計
因爲Advisor鏈須要的是MethodInterceptor(攔截器)對象,因此每個Advisor中的Advice都要適配成對應的MethodInterceptor對象。代理
五.包裝器(Decorator)
動態地給一個對象添加一些額外的職責。就增長功能來講,Decorator模式相比生成子類更爲靈活。視頻
Spring中用到的包裝器模式在類名上有兩種表現:一種是類名中含有Wrapper,另外一種是類名中含有Decorator。基本上都是動態地給一個對象添加一些額外的職責。
六. 代理(Proxy)
爲其餘對象提供一種代理以控制對這個對象的訪問。
從結構上來看和Decorator模式相似,但Proxy是控制,更像是一種對功能的限制,而Decorator是增長職責。
Spring的Proxy模式在aop中有體現,好比JdkDynamicAopProxy和Cglib2AopProxy。
七.觀察者(Observer)
定義對象間的一種一對多的依賴關係,當一個對象的狀態發生改變時,全部依賴於它的對象都獲得通知並被自動更新。
Spring中Observer模式經常使用的地方是listener的實現。如ApplicationListener。
八. 策略(Strategy)
定義一系列的算法,把它們一個個封裝起來,而且使它們可相互替換。本模式使得算法可獨立於使用它的客戶而變化。
Spring中在實例化對象的時候用到Strategy模式,見以下圖:
在SimpleInstantiationStrategy中有以下代碼說明了策略模式的使用狀況:
九.模板方法(Template Method)
定義一個操做中的算法的骨架,而將一些步驟延遲到子類中。Template Method使得子類能夠不改變一個算法的結構便可重定義該算法的某些特定步驟。
Template Method模式通常是須要繼承的。這裏想要探討另外一種對Template Method的理解。Spring中的JdbcTemplate,在用這個類時並不想去繼承這個類,由於這個類的方法太多,可是咱們仍是想用到JdbcTemplate已有的穩定的、公用的數據庫鏈接,那麼咱們怎麼辦呢?咱們能夠把變化的東西抽出來做爲一個參數傳入JdbcTemplate的方法中。可是變化的東西是一段代碼,並且這段代碼會用到JdbcTemplate中的變量。怎麼辦?那咱們就用回調對象吧。在這個回調對象中定義一個操縱JdbcTemplate中變量的方法,咱們去實現這個方法,就把變化的東西集中到這裏了。而後咱們再傳入這個回調對象到JdbcTemplate,從而完成了調用。這多是Template Method不須要繼承的另外一種實現方式吧。
如下是一個具體的例子:
JdbcTemplate中的execute方法
JdbcTemplate執行execute方法:
寫在最後
最後,須要Java架構視頻和資料的朋友能夠加羣 147033995 免費領取
比你優秀的對手在學習,你的仇人在磨刀,你的閨蜜在減肥,隔壁老王在練腰, 咱們必須不斷學習,不然咱們將被學習者超越!
趁年輕,使勁拼,給將來的本身一個交代!