自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

這些Spring中的設(shè)計模式,你都知道嗎?

開發(fā) 后端
設(shè)計模式作為工作學(xué)習(xí)中的枕邊書,卻時常處于勤說不用的尷尬境地,也不是我們時常忘記,只是一直沒有記憶。Spring作為業(yè)界的經(jīng)典框架,無論是在架構(gòu)設(shè)計方面,還是在代碼編寫方面,都堪稱行內(nèi)典范。

[[257003]]

導(dǎo)讀:設(shè)計模式作為工作學(xué)習(xí)中的枕邊書,卻時常處于勤說不用的尷尬境地,也不是我們時常忘記,只是一直沒有記憶。Spring作為業(yè)界的經(jīng)典框架,無論是在架構(gòu)設(shè)計方面,還是在代碼編寫方面,都堪稱行內(nèi)典范。

好了,話不多說,開始今天的內(nèi)容。spring中常用的設(shè)計模式達(dá)到九種,我們舉例說明。

簡單工廠模式

又叫做靜態(tài)工廠方法(StaticFactory Method)模式,但不屬于23種GOF設(shè)計模式之一。 

簡單工廠模式的實質(zhì)是由一個工廠類根據(jù)傳入的參數(shù),動態(tài)決定應(yīng)該創(chuàng)建哪一個產(chǎn)品類。 

spring中的BeanFactory就是簡單工廠模式的體現(xiàn),根據(jù)傳入一個***的標(biāo)識來獲得bean對象,但是否是在傳入?yún)?shù)后創(chuàng)建還是傳入?yún)?shù)前創(chuàng)建這個要根據(jù)具體情況來定。如下配置,就是在 HelloItxxz 類中創(chuàng)建一個 itxxzBean。 

  1. <beans>  
  2.   <bean id="singletonBean" class="com.itxxz.HelloItxxz">  
  3.      <constructor-arg>  
  4.        <value>Hello! 這是singletonBean!value>  
  5.      </constructor-arg>  
  6.  </ bean>  
  7.  <bean id="itxxzBean" class="com.itxxz.HelloItxxz"  singleton="false">  
  8.    <constructor-arg>  
  9.        <value>Hello! 這是itxxzBean! value>  
  10.    </constructor-arg>  
  11.  </bean>  
  12. </beans> 

工廠方法模式

通常由應(yīng)用程序直接使用new創(chuàng)建新的對象,為了將對象的創(chuàng)建和使用相分離,采用工廠模式,即應(yīng)用程序?qū)ο蟮膭?chuàng)建及初始化職責(zé)交給工廠對象。

一般情況下,應(yīng)用程序有自己的工廠對象來創(chuàng)建bean.如果將應(yīng)用程序自己的工廠對象交給Spring管理,那么Spring管理的就不是普通的bean,而是工廠Bean。

就以工廠方法中的靜態(tài)方法為例講解一下: 

  1. import java.util.Random;  
  2. public class StaticFactoryBean {  
  3.  public static Integer createRandom() {  
  4.       return new Integer(new Random().nextInt());  
  5.   }  

建一個config.xm配置文件,將其納入Spring容器來管理,需要通過factory-method指定靜態(tài)方法名稱: 

  1. <bean id="random"  
  2. class="example.chapter3.StaticFactoryBean" factory-method="createRandom"  
  3. scope="prototype"  
  4. /> 

測試: 

  1. public static void main(String[] args) {  
  2. //調(diào)用getBean()時,返回隨機(jī)數(shù).如果沒有指定factory-method,會返回StaticFactoryBean的實例,即返回工廠Bean的實例    
  3. XmlBeanFactory factory = new XmlBeanFactory(new ClassPathResource("config.xml"));     
  4. System.out.println("我是IT學(xué)習(xí)者創(chuàng)建的實例:"+factory.getBean("random").toString());  

單例模式

保證一個類僅有一個實例,并提供一個訪問它的全局訪問點。 

spring中的單例模式完成了后半句話,即提供了全局的訪問點BeanFactory。但沒有從構(gòu)造器級別去控制單例,這是因為spring管理的是是任意的java對象。 

核心提示點:Spring下默認(rèn)的bean均為singleton,可以通過singleton=“true|false” 或者 scope="?"來指定。

適配器模式

在Spring的Aop中,使用的Advice(通知)來增強(qiáng)被代理類的功能。Spring實現(xiàn)這一AOP功能的原理就使用代理模式(1、JDK動態(tài)代理。2、CGLib字節(jié)碼生成技術(shù)代理。)對類進(jìn)行方法級別的切面增強(qiáng),即,生成被代理類的代理類, 并在代理類的方法前,設(shè)置攔截器,通過執(zhí)行攔截器重的內(nèi)容增強(qiáng)了代理方法的功能,實現(xiàn)的面向切面編程。

Adapter類接口:Target 

  1. public interface AdvisorAdapter {  
  2. boolean supportsAdvice(Advice advice);  
  3.  MethodInterceptor getInterceptor(Advisor advisor);  
  4. } MethodBeforeAdviceAdapter類,Adapter  
  5. class MethodBeforeAdviceAdapter implements AdvisorAdapter, Serializable {  
  6.  public boolean supportsAdvice(Advice advice) {  
  7.        return (advice instanceof MethodBeforeAdvice);  
  8.  }  
  9.  public MethodInterceptor getInterceptor(Advisor advisor) {  
  10.        MethodBeforeAdvice advice = (MethodBeforeAdvice) advisor.getAdvice();  
  11.  return new MethodBeforeAdviceInterceptor(advice);  
  12.  }  

包裝器模式

在我們的項目中遇到這樣一個問題:我們的項目需要連接多個數(shù)據(jù)庫,而且不同的客戶在每次訪問中根據(jù)需要會去訪問不同的數(shù)據(jù)庫。我們以往在spring和hibernate框架中總是配置一個數(shù)據(jù)源,因而sessionFactory的dataSource屬性總是指向這個數(shù)據(jù)源并且恒定不變,所有DAO在使用sessionFactory的時候都是通過這個數(shù)據(jù)源訪問數(shù)據(jù)庫。

但是現(xiàn)在,由于項目的需要,我們的DAO在訪問sessionFactory的時候都不得不在多個數(shù)據(jù)源中不斷切換,問題就出現(xiàn)了:如何讓sessionFactory在執(zhí)行數(shù)據(jù)持久化的時候,根據(jù)客戶的需求能夠動態(tài)切換不同的數(shù)據(jù)源?我們能不能在spring的框架下通過少量修改得到解決?是否有什么設(shè)計模式可以利用呢? 

首先想到在spring的applicationContext中配置所有的dataSource。這些dataSource可能是各種不同類型的,比如不同的數(shù)據(jù)庫:Oracle、SQL Server、MySQL等,也可能是不同的數(shù)據(jù)源:比如apache 提供的org.apache.commons.dbcp.BasicDataSource、spring提供的org.springframework.jndi.JndiObjectFactoryBean等。然后sessionFactory根據(jù)客戶的每次請求,將dataSource屬性設(shè)置成不同的數(shù)據(jù)源,以到達(dá)切換數(shù)據(jù)源的目的。

spring中用到的包裝器模式在類名上有兩種表現(xiàn):一種是類名中含有Wrapper,另一種是類名中含有Decorator?;旧隙际莿討B(tài)地給一個對象添加一些額外的職責(zé)。 

代理模式

為其他對象提供一種代理以控制對這個對象的訪問。  從結(jié)構(gòu)上來看和Decorator模式類似,但Proxy是控制,更像是一種對功能的限制,而Decorator是增加職責(zé)。 

spring的Proxy模式在aop中有體現(xiàn),比如JdkDynamicAopProxy和Cglib2AopProxy。 

觀察者模式

定義對象間的一種一對多的依賴關(guān)系,當(dāng)一個對象的狀態(tài)發(fā)生改變時,所有依賴于它的對象都得到通知并被自動更新。

spring中Observer模式常用的地方是listener的實現(xiàn)。如ApplicationListener。 

策略模式

定義一系列的算法,把它們一個個封裝起來,并且使它們可相互替換。本模式使得算法可獨立于使用它的客戶而變化。 

spring中在實例化對象的時候用到Strategy模式

在SimpleInstantiationStrategy中有如下代碼說明了策略模式的使用情況: 

模板方法模式

定義一個操作中的算法的骨架,而將一些步驟延遲到子類中。Template Method使得子類可以不改變一個算法的結(jié)構(gòu)即可重定義該算法的某些特定步驟。

Template Method模式一般是需要繼承的。這里想要探討另一種對Template Method的理解。spring中的JdbcTemplate,在用這個類時并不想去繼承這個類,因為這個類的方法太多,但是我們還是想用到JdbcTemplate已有的穩(wěn)定的、公用的數(shù)據(jù)庫連接,那么我們怎么辦呢?我們可以把變化的東西抽出來作為一個參數(shù)傳入JdbcTemplate的方法中。但是變化的東西是一段代碼,而且這段代碼會用到JdbcTemplate中的變量。怎么辦?那我們就用回調(diào)對象吧。

在這個回調(diào)對象中定義一個操縱JdbcTemplate中變量的方法,我們?nèi)崿F(xiàn)這個方法,就把變化的東西集中到這里了。然后我們再傳入這個回調(diào)對象到JdbcTemplate,從而完成了調(diào)用。這可能是Template Method不需要繼承的另一種實現(xiàn)方式。 

以下是一個具體的例子: 

JdbcTemplate中的execute方法 

 JdbcTemplate執(zhí)行execute方法 

責(zé)任編輯:龐桂玉 來源: Java團(tuán)長
相關(guān)推薦

2022-11-10 09:00:41

2021-07-29 06:55:03

Spring@AutowriedbyType注入

2021-08-05 18:21:29

Autowired代碼spring

2023-02-15 08:12:19

http超時過濾器

2020-05-27 11:30:54

Chrome DevT前端命令

2024-11-26 14:29:48

2016-01-11 09:48:07

2016-03-18 19:03:35

認(rèn)知計算IBM

2019-07-08 10:18:38

MPLSIP數(shù)據(jù)

2024-03-26 10:10:45

JavaScript操作符操作表達(dá)式

2022-09-07 09:01:14

JS操作符運算符

2019-11-07 11:49:14

架構(gòu)運維技術(shù)

2023-04-28 12:37:59

Spring@Bean使用方式

2023-04-23 09:50:50

@BeanSpring

2024-04-28 08:20:52

Controller接口URL

2018-07-04 11:02:23

無線傳輸模式

2021-04-10 07:04:00

WPS技巧辦公軟件

2020-10-28 11:20:55

vue項目技

2023-08-29 09:31:01

Scrapy網(wǎng)頁爬蟲

2020-02-20 08:30:49

OSPF網(wǎng)絡(luò)協(xié)議路由協(xié)議
點贊
收藏

51CTO技術(shù)棧公眾號