java Spring中使用到的设计模式

这篇具有很好参考价值的文章主要介绍了java Spring中使用到的设计模式。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

单例模式

单例模式(Singleton Pattern)是java中最简单的设计模式之一。这种类型的设计模式属于创建型模式,它提供了一种创建对象的最佳方式。这种模式涉及到一个单一的类,该类负责创建自己的对象,同时确保只有单个对象被创建。这个类提供了一种访问其唯一对象的方式,可以直接访问,不需要实例化该类的对象。
注意:
(1)单例类只能有一个实例。
(2)单例类必须自己创建自己的唯一实例。
(3)单例类必须给所有其他对象提供这一实例。

优点:
(1)在内存里面只有一个实例,减少了内存的开销,尤其是平凡创建和销毁实例。
(2)避免对文件的多重占用(比如写文件操作)。

缺点:没有接口,不能继承,与单一职责原则冲突,一个类应该只关心内部逻辑,而不关心外面怎么样来实例化。

使用场景:
(1)要求生产唯一序列号。
(2)Web中的计数器,不用每次刷新都在数据库里加一次,用单例先缓存起来。
(3)创建的一个对象需要消耗的资源过多,比如I/O与数据库的链接等。

注意事项:getInstance()方法中需要使用同步锁synchronized(Singleton.class)防止多线程同时进入造成instance被多次实例化。

实现:

	public class SingleObject {
		//创建SingleOject的一个对象
		private static SingleObject instance = new SingleObject();
		
		//让构造器函数为private,这样类就不会被实例化
		private SingleObject(){};

		//获取唯一可用的对象
		public static SingleObject getInstance(){
			return instance;
	}
		public void showMessage(){
			System.out.println("aaaa");
		}
}
	

Spring中定义的bean默认为单例模式,保证每一个类中仅有一个实例,并提供一个访问它的全局访问点。spring中的单例模式提供了全局访问点BeanFactory。但没有从构造器级别去控制单例,这是因为spring管理的是任意的java对象。

单例模式的几种实现方式

(1)懒汉式,线程不安全
这种方式是最基本的实现方式,这种实现的最大的问题就是不支持多线程。因为没有加锁synchronized,所以严格意义上不算单例模式。

public class Singleton {  
    private static Singleton instance;  
    private Singleton (){}  
  
    public static Singleton getInstance() {  
        if (instance == null) {  
            instance = new Singleton();  
        }  
        return instance;  
    }  
}

(2)懒汉式,线程安全
能够在多线程中很好的工作,但是效率很低,99%的情况下不需要同步。
优点:第一次调用才初始化,避免内存浪费。
缺点:必须加synchronized才能保证单例,但加锁会影响效率。

public class Singleton {  
    private static Singleton instance;  
    private Singleton (){}  
    public static synchronized Singleton getInstance() {  
        if (instance == null) {  
            instance = new Singleton();  
        }  
        return instance;  
    }  
}

(3)饿汉式
这种方法比较常用,但容易产生垃圾对象。
优点:没有加锁,执行效率会提高。
缺点:类加载时就初始化,浪费内存。
它基于classloader机制避免了多线程的同步问题,不过,instance在类装载时就实例化。

public class Singleton {  
    private static Singleton instance = new Singleton();  
    private Singleton (){}  
    public static Singleton getInstance() {  
    return instance;  
    }  
}

(4)双检索/双重校验锁(DCL,即double-checked locking)
这种方式采用双锁机制,安全且在多线程情况下保持高性能。

public class Singleton {  
    private volatile static Singleton singleton;  
    private Singleton (){}  
    public static Singleton getSingleton() {  
    if (singleton == null) {  
        synchronized (Singleton.class) {  
            if (singleton == null) {  
                singleton = new Singleton();  
            }  
        }  
    }  
    return singleton;  
    }  
}

(5)登记式/静态内部类
这种方式能达到双检锁方式一样的功效,但实现更简单。对静态域使用延迟初始化,应该使用这种方式而不是双检锁方式。
这种方式同样使用了classLoader机制来保证初始化instace时只有一个线程,它跟第三种方式不同的是:第3种方式只要Singleton类被装载了,那么instance就会被实例化,而这种方式是Singleton类被撞在了,instance不一定被初始化。因为SingletonHolder类没有被主动使用,只有通过显式调用getInstance方法时,才会显式装载Singleton类,从而实例化instance。

public class Singleton {
	private static class SingletonHolder {
		private static finale Singleton INSTANCE = new Singleton(); 
	}

	private Singleton (){};
	public static final Singleton getInstance(){
		return SingletonHolder.INSTANCE;
	}
}

(6)枚举
这是实现单例模式的最佳方法。它更简洁,自动支持序列化机制,防止被多次实例化。

public enum Singleton {  
    INSTANCE;  
    public void whateverMethod() {  
    }  
}

总结:一般情况下,不建议使用第一种和第二种懒汉方式,建议使用第三种饿汉方式,只有在明确要实现lazy loading 效果时,才会使用第五种登记方式。如果涉及到反序列化创建对象时,可以尝试使用第六种枚举方式。

工厂模式

工厂模式(Factory Pattern)是Java中最常用的设计模式之一。这种类型的设计模式属于创建型模式。它提供了一种创建对象的最佳模式。在工厂模式中,我们在创建对象时不会对客户端暴露创建逻辑,并且通过使用一个共同的接口来指向新创建的对象。

优点:
(1)一个调用者想创建一个对象,只要知道其名称就可以了。
(2)扩展性高,如果想要增加一个产品,只要扩展一个工厂类就可以了。
(3)屏蔽产品的具体实现,调用者只关心产品的接口。

注意事项:作为一种创建类模式,在任何需要生成复杂对象的地方,都可以使用工厂方法模式。有一点需要注意的地方就是复杂对象适合使用工厂模式,而简单对象,特别是只需要通过new就可以完成创建的对象,无需使用工厂模式。如果使用工程模式,就需要引入一个工厂类,会增加系统的复杂度。

使用场景:
(1)日志记录器:记录可以记录到本地磁盘、系统事件、远程服务器等,用户可以选择日志记录到什么地方。
(2)数据库访问,当用户不知道最后系统采用哪一类数据库时,以及数据库可能有变化时。
(3)设计一个连接服务器的框架,需要三个协议,“POP3”,“IMAP”,“HTTP”,可以把三个作为产品类,实现同一个接口。

Spring中使用工厂模式通过BeanFactory、ApplicationContext创建Bean对象。

实现方式:
我们创建一个Shape接口和实现Shape接口的实体类。下一步是定义工厂类ShapeFactory。
FactoryPatternDemo类使用ShapeFactory来获取Shape对象。它将向ShapeFactory传递信息(CIRCLE / RECTANGLE / SQUARE),以便获取它所需对象的类型。

步骤一:创建一个接口

public insterface Shape{
	void draw();
}

步骤二:创建实现接口的实体类

public class Rectangle implements Shape{
	@Override
	public void draw() {
		System.out.println("Inside Rectangle::draw() method.");
	}
}
public class Square implements Shape {
 
   @Override
   public void draw() {
      System.out.println("Inside Square::draw() method.");
   }
}
public class Circle implements Shape {
 
   @Override
   public void draw() {
      System.out.println("Inside Circle::draw() method.");
   }
}

步骤三:创建一个工厂,生成基于给定信息的实体类的对象

public class ShapeFactory{
	//使用getShape方法获取形状类型的对象
	public Shape getShape(String shapeType) {
		if (shapeType == null) {
			return null;
		}
 		if(shapeType.equalsIgnoreCase("CIRCLE")){
         return new Circle();
    	} else if(shapeType.equalsIgnoreCase("RECTANGLE")){
         return new Rectangle();
      	} else if(shapeType.equalsIgnoreCase("SQUARE")){
         return new Square();
      	}
      	return null;
	}
}

步骤四:使用该工厂,通过传递

public class FactoryPatternDemo {
 
   public static void main(String[] args) {
      ShapeFactory shapeFactory = new ShapeFactory();
 
      //获取 Circle 的对象,并调用它的 draw 方法
      Shape shape1 = shapeFactory.getShape("CIRCLE");
 
      //调用 Circle 的 draw 方法
      shape1.draw();
 
      //获取 Rectangle 的对象,并调用它的 draw 方法
      Shape shape2 = shapeFactory.getShape("RECTANGLE");
 
      //调用 Rectangle 的 draw 方法
      shape2.draw();
 
      //获取 Square 的对象,并调用它的 draw 方法
      Shape shape3 = shapeFactory.getShape("SQUARE");
 
      //调用 Square 的 draw 方法
      shape3.draw();
   }
}

抽象工厂模式

抽象工厂模式(Abstract Factory Pattern)是围绕一个超级工厂创建其他工厂,该超级工厂又称为其他工厂的工厂。这种类型的设计模式属于创建型模式,它提供了一种创建对象的最佳方式。
在抽象工厂模式中,接口是负责创建一个相关对象的工厂,不需要显式地指定它们的类,每个生成的工厂都能按照工厂模式提供对象。

优点:当一个产品族中的多个对象被设计成一起工作时,它能保证客户端始终只使用同一个产品族中的对象。
缺点:产品族扩展非常困难,要增加一个系列的某一产品,既要在抽象的Creator里加代码,又要在具体的里面加代码。

使用场景:
(1)QQ换皮肤,一整套一起换
(2)生成不同操作系统的程序

注意事项:
产品族难扩展, 产品等级易扩展

策略模式

在策略模式中,一个类的行为或其算法可以在运行时更改。这种类型的设计模式属于行为型模式。
在策略模式中,我们创建表示各种策略的对象和一个行为随着策略对象改变而改变的context对象。策略对象改变context对象的执行算法。

意图:定义一系列的算法,把他们一个个封装起来,并且使他们可相互替换。
主要解决:在多种算法相似的情况下,使用if…else所带来的复杂和难以维护。
何时使用:一个系统有许多类,而区分它们的只是他们直接的行为。
如何解决:将这些算法封装成一个一个的类,任意的替换。

优点:
(1)算法可以自由切换。
(2)避免使用多重条件判断。
(3)扩展性良好。

缺点:
(1)策略类会增多。
(2)所有策略类都需要对外暴露。

Spring中资源访问接口Resource的设计是一种经典的策略模式。Resource接口是所有资源访问类所实现的接口,Resource接口就代表资源访问策略,但具体采用哪种策略实现,Resource接口并不理会。客户端程序只和Resource接口耦合,并不知道底层采用何种资源访问策略,这样客户端可以再不同的资源访问策略之间自由切换。

实现方法:
创建一个定义活动的Strategy接口和实现了Strategy

步骤一:

创建一个接口:

public interface Strategy {
   public int doOperation(int num1, int num2);
}

步骤二

创建接口的实现类

public class OperationAdd implements Strategy{
   @Override
   public int doOperation(int num1, int num2) {
      return num1 + num2;
   }
}
public class OperationSubtract implements Strategy{
   @Override
   public int doOperation(int num1, int num2) {
      return num1 - num2;
   }
}
public class OperationMultiply implements Strategy{
   @Override
   public int doOperation(int num1, int num2) {
      return num1 * num2;
   }
}

步骤三

创建Context类

public class Context {
   private Strategy strategy;
 
   public Context(Strategy strategy){
      this.strategy = strategy;
   }
 
   public int executeStrategy(int num1, int num2){
      return strategy.doOperation(num1, num2);
   }
}

步骤四

使用Context来 查看当它改变策略Strategy时的行为变化

public class StrategyPatternDemo {
   public static void main(String[] args) {
      Context context = new Context(new OperationAdd());    
      System.out.println("10 + 5 = " + context.executeStrategy(10, 5));
 
      context = new Context(new OperationSubtract());      
      System.out.println("10 - 5 = " + context.executeStrategy(10, 5));
 
      context = new Context(new OperationMultiply());    
      System.out.println("10 * 5 = " + context.executeStrategy(10, 5));
   }
}

代理模式

在代理模式中,一个类代表另一个类的功能。这种类型的设计模式属于结构型模式。在代理模式中,我们创建具有现有对象的对象,以便向外界提供功能接口。

java Spring中使用到的设计模式,java,spring,设计模式文章来源地址https://www.toymoban.com/news/detail-601073.html

到了这里,关于java Spring中使用到的设计模式的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • JAVA设计模式第七讲:设计模式在 Spring 源码中的应用

    设计模式(design pattern)是对软件设计中普遍存在的各种问题,所提出的解决方案。本文以面试题作为切入点,介绍了设计模式的常见问题。 我们需要掌握各种设计模式的原理、实现、设计意图和应用场景,搞清楚能解决什么问题 。 本文是第七篇:设计模式在 Spring 源码中的

    2024年02月09日
    浏览(41)
  • Java 设计者模式以及与Spring关系(七) 命令和迭代器模式

    本文是个系列一次会出两个设计者模式作用,如果有关联就三个,除此外还会讲解在spring中作用。 23设计者模式以及重点模式 我们都知道 设计者模式 有 3 类 23 种设计模式,标红是特别重要的设计者模式建议都会,而且熟读于心,标蓝是指其次重要建议也要明白。 (1)创建

    2024年01月24日
    浏览(35)
  • Java 设计者模式以及与Spring关系(六) 装饰和模版方法模式

    本文是个系列一次会出两个设计者模式作用,如果有关联就三个,除此外还会讲解在spring中作用。 23设计者模式以及重点模式 我们都知道 设计者模式 有 3 类 23 种设计模式,标红是特别重要的设计者模式建议都会,而且熟读于心,标蓝是指其次重要建议也要明白。 (1)创建

    2024年01月24日
    浏览(41)
  • Spring中使用了哪些设计模式

    1、工厂模式 在各种BeanFactory以及ApplicationContext创建中都用到了。 2、模板模式 在各种BeanFactory以及ApplicationContext实现中也都用到了。 3、代理模式 Spring AOP 利用了AspectJ AOP实现的,AspectJ AOP底层使用了动态代理。 4、策略模式 加载资源文件的方式,使用了不同的方法,如ClassP

    2024年02月09日
    浏览(36)
  • 什么是 Spring 框架?使用 Spring 框架的好处是什么?Spring 框架中用到了哪些设计模式?列举一些重要的Spring模块?

    Spring 是一种轻量级开发框架,旨在提高开发人员的开发效率以及系统的可维护性。 Spring 官网 :https://spring.io/ Spring 框架指的是 Spring Framework ,它是很多模块的集合,使用这些模块可以很方便地协助我们进行开发。         这些 模块 是:核心容器、数据访问/集成,、Web、

    2024年02月13日
    浏览(44)
  • 【Spring】Spring中的设计模式

    责任链模式介绍 Spring源码介绍 spring中Aop的责任链模式,相对于传统的责任链模式做了一定的改造。 传统的设计模式,抽象处理者会有一个方法设置和获取具体处理者的下一个处理者的方法。 如: 但是Spring中的责任链模式没有这两个方法,而是抽出一个公共的处理方法,方

    2024年02月14日
    浏览(41)
  • spring的设计模式----简单工厂模式

    spring中IoC 控制反转,底层是工厂模式。 工厂模式(Factory Pattern)是 Java 中最常用的设计模式之一。这种类型的设计模式属于创建型模式,它提供了一种创建对象的最佳方式。 工厂模式提供了一种将对象的实例化过程封装在工厂类中的方式。通过使用工厂模式,可以将对象的

    2024年02月17日
    浏览(46)
  • Spring学习笔记(二)Spring的控制反转(设计原则)与依赖注入(设计模式)

    是一种设计原则,降低程序代码之间的耦合度 对象由Ioc容器统一管理,当程序需要使用对象时直接从IoC容器中获取。这样对象的控制权就从应用程序转移到了IoC容器 依赖注入是一种消除类之间依赖关系的设计模式。例如,A类要依赖B类,A类不再直接创建B类,而是把这种依赖

    2024年02月19日
    浏览(37)
  • Spring中的设计模式

    目录 1.Spring中使用到的设计模式有: 2.工厂模式 3.单例模式 4.代理模式 5.模板模式 6.适配器模式         工厂模式:实现IoC容器         单例模式:将bean设置为单例         代理模式:AOP的底层实现         模板模式:比如引入jdbc依赖后出现的jdbcTemplate         适配器模

    2024年02月12日
    浏览(44)
  • spring用到的设计模式

    在Spring中,默认情况下,Spring容器中的所有Bean都是单例(Singleton)的,也就是说,Spring容器中每个Bean的实例只有一个。这是因为Spring默认使用单例模式来创建Bean,确保每个Bean在整个应用中只有一个实例,从而提高应用性能和资源利用率。 在Spring中,单例 Bean 是 Spring Appli

    2024年02月08日
    浏览(37)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包