1.简单工厂模式

又叫做静态工厂模式

简单工厂模式实质是有一个工厂类根据传入的参数,动态决定应该创建哪一个产品类。


<beans> 

 
com.itxxz.HelloItxxz"> 

 

          <constructor-arg> 

 

              <value>Hello! 这是singletonBean!value> 

 

          </constructor-arg> 

 

     </ bean> 

 

    

 
itxxzBean" class=" 
 com.itxxz.HelloItxxz" 

 

          singleton="false"> 

 

          <constructor-arg> 

 
itxxzBean! value> 

 

          </constructor-arg> 

 

      </bean> 

 

    

 

  </beans>


2.工厂方法

通常由应用程序直接使用new创建新的想,为了将对象的创建和使用相分离,采用工厂模式,即应用程序将对象的创建及初始化职责交给工厂对象。

一般情况下,应用程序有自己的工厂对象来创建bean。如果将应用程序自己的工厂对象交给spring管理,那么spring管理的就是普通的bean,而是工厂bean


import java.util.Random; 

 

  public class StaticFactoryBean { 

 

        public static Integer createRandom() { 

 

             return new Integer(new Random().nextInt()); 

 

         } 

 

  }


建一个config.xm配置文件,将其纳入Spring容器来管理,需要通过factory-method指定静态方法名称


<bean id="random" 

 

  class="example.chapter3.StaticFactoryBean" factory-method="createRandom" //createRandom方法必须是static的,才能找到 scope="prototype" 

 

  /> 

 

  测试: 

 

  public static void main(String[] args) { 
 
       //调用getBean()时,返回随机数.如果没有指定factory-method,会返回StaticFactoryBean的实例,即返回工厂Bean的实例       XmlBeanFactory factory = new XmlBeanFactory(new ClassPathResource("config.xml"));       System.out.println("我是IT学习者创建的实例:"+factory.getBean("random").toString()); 
 

  }




3.单例模式

保证一个类中只有一个实例,并提供一个访问它的全局访问点。


4.适配器

在spring的Aop中,使用的Advice来增强被代理类的功能。spring实现这一Aop功能的原理就使用代理模式(1.jdk动态代理 2.cglib字节码生成技术代理)对类进行方法级别的切面增强,


public interface AdvisorAdapter { 

 

    

 

  boolean supportsAdvice(Advice advice); 

 

    

 

        MethodInterceptor getInterceptor(Advisor advisor); 

 

    

 
MethodBeforeAdviceAdapter类 
  , 
  Adapter
 
 

   class MethodBeforeAdviceAdapter implements AdvisorAdapter, Serializable { 
 


         public boolean supportsAdvice(Advice advice) { 
 
 
 

               return (advice instanceof MethodBeforeAdvice); 
 
 
 

         } 
 
 

         public MethodInterceptor getInterceptor(Advisor advisor) { 
 
 
 

               MethodBeforeAdvice advice = (MethodBeforeAdvice) advisor.getAdvice(); 
 
 
 

         return new MethodBeforeAdviceInterceptor(advice); 
 
 
 

         } 
 
 
 

     
 
 
 

   }


5.包装器

在我们的项目中遇到这样一个问题:我们的项目需要连接多个数据库,而且不同的客户在每次访问中根据需要会去访问不同的数据库。我们以往在spring和hibernate框架中总是配置一个数据源,因而sessionFactory的dataSource属性总是指向这个数据源并且恒定不变,所有DAO在使用sessionFactory的时候都是通过这个数据源访问数据库。但是现在,由于项目的需要,我们的DAO在访问sessionFactory的时候都不得不在多个数据源中不断切换,问题就出现了:如何让sessionFactory在执行数据持久化的时候,根据客户的需求能够动态切换不同的数据源?我们能不能在spring的框架下通过少量修改得到解决?是否有什么设计模式可以利用呢? 
首先想到在spring的applicationContext中配置所有的dataSource。这些dataSource可能是各种不同类型的,比如不同的数据库:Oracle、SQL Server、MySQL等,也可能是不同的数据源:比如apache 提供的org.apache.commons.dbcp.BasicDataSource、spring提供的org.springframework.jndi.JndiObjectFactoryBean等。然后sessionFactory根据客户的每次请求,将dataSource属性设置成不同的数据源,以到达切换数据源的目的。
spring中用到的包装器模式在类名上有两种表现:一种是类名中含有Wrapper,另一种是类名中含有Decorator。基本上都是动态地给一个对象添加一些额外的职责。 

6.代理

为其他对象提供一种以控制对这个对象的访问

7.观察者

定义对象间的一种一对多的依赖关系,当一个对象的状态发生改变时,所有依赖于它的对象得到通知并自动更新。8.

8.策略 9.模板