设计模式-单例模式

本文详细介绍了单例模式的定义、应用场景、优缺点以及在Spring框架中的应用。通过饿汉式、懒汉式、静态内部类和枚举四种实现方式,展示了如何在Java中创建和管理单例对象。此外,还讨论了单例模式可能带来的问题,如拓展性差和资源浪费,并提供了相应的解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1. 定义

一个类仅有一个实例,并提供一个访问它的全局访问点

2. 应用场景

工具类,线程池,日志对象,缓存

3. 优点

提供对唯一实例的受控访问

只存在一个对象,节约系统资源

4. 缺点

不是抽象的,拓展性差

共享过多,比如连接池,连接数不够用

长时间不使用,被垃圾回收

5. Sping 中的应用

Spring 中的依赖注入中应用了单例,
其中的方法 getSingleton() 实现了懒汉式。
在配置文件中配置注册bean对象的时候**「设置scope的值为singleton」**

6. 代码

6.1. 饿汉

静态属性或静态代码初始化单例对象;
JVM加载 class 时实例化对象。

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

6.2. 懒汉

获取对象时,实例化对象;
对象需要使用 volatile 关键字,避免因指令重排序造成的,返回了对象地址,但对象尚未创建的问题;
使用同步代码块来实例化对象;
两次 null 值判断,同步代码块内外各进行一次 null 值判断,避免并发问题。

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

6.3. 静态内部类

获取对象时,加载内部类,执行内部类的静态代码。

public class Singleton {
  private Singleton() {}
  private static class Inner {
    private static final Singleton INS = new Singleton();
  }
  public static Singleton getInstance() {
    return Inner.INS;
  }
}

6.4. 枚举

public enum Singleton {
  INS;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值