单例模式,与Spring的结合

单例模式:保证系统中一个类只有一个实例

1. 饿汉式单例

静态常量

/**
 * 饿汉式单例:在类加载的初始化阶段就完成了实例化,使用JVM来解决了线程同步问题
 * JVM中,初始化类时只有一个线程在操作
 */
public class HungrySingleton1 {
    private static final HungrySingleton1 instance=new HungrySingleton1();
    //私有构造方法,禁止在其他类中创建实例
    private HungrySingleton1(){}
    //静态工厂方法  
    public static HungrySingleton1 getInstance(){
        return instance;
    }

}

 静态代码块

/**
 * 饿汉式单例:在类加载的初始化阶段就完成了实例化,使用JVM来解决了线程同步问题
 * JVM中,初始化类时只有一个线程在操作
 */
public class HungrySingleton2 {

    private static HungrySingleton2 instance;

    static {
        instance = new HungrySingleton2();
    }
    //私有构造方法,禁止在其他类中创建实例
    private HungrySingleton2() {}

    public static HungrySingleton2 getInstance() {
        return instance;
    }
}

2. 懒汉式单例:


/**
 * @Author Snail
 * @Describe 懒汉式单例:双重校验加锁
 * @CreateTime 2019/6/22
 */
public class LazySingleton {

    private volatile static LazySingleton lazySingleton;

    private LazySingleton() {
    }

    public static LazySingleton getInstance() {
        if (lazySingleton == null) {            //1
            synchronized (LazySingleton.class) {
                if (lazySingleton == null) {    //2
                    lazySingleton = new LazySingleton();
                }
            }
        }
        return lazySingleton;
    }

}

为什么要使用双重判断:

对于同步外的空判断(1处),可以提高系统性能。如果去掉后,单例类也能被安全创建,但在多线程竞争情况下,会出现多线程等待锁的情况;如果有判断是否为空,那么在一个线程创建完单例类,但未释放锁时,其他线程就不会去等待获取锁,而是直接去拿单例类。

对于同步内的空判断(2处),是保证单例类被安全创建必要的判断

3. 双重判断加锁的单例注册表模式(spring中使用的方式):

使用HashMap存储单例类,使用双重判断加锁的方法,来保证只创建一个单例。

源码参考:https://www.cnblogs.com/nickup/p/9800120.html

 

Bean的五种作用域(scope):

singleton(默认,单例)

prototype(每次获取bean时,都会创建一个类)

session

request(每次请求都会创建要给新类)

global session

Bean作用域参考:https://blog.csdn.net/icarus_wang/article/details/51586776

 

 

Spring框架中,单例模式是一种常见的设计模式,用于确保在整个应用生命周期中只有一个实例存在。虽然Spring本身已经提供了基于Bean的单例模式支持,但如果你想要手动实现一个简单的Spring风格的单例,你可以按照以下步骤: 1. **静态工厂方法**: - 创建一个私有的构造函数,仅允许通过工厂方法创建实例。 ```java public class Singleton { private static volatile Singleton instance; private Singleton() {} public static Singleton getInstance() { if (instance == null) { synchronized (Singleton.class) { if (instance == null) { instance = new Singleton(); } } } return instance; } } ``` 2. **双重校验锁定(DCL)**: - 使用双重检查锁定优化,避免了同步块导致的性能开销。 ```java public class SingletonDCL { private volatile static Singleton instance; private SingletonDCL() {} public static Singleton getInstance() { if (instance == null) { instance = new SingletonDCL(); } return instance; } } ``` 3. **枚举类型单例**: - 使用枚举类型保证线程安全且易于理解。 ```java public enum SingletonEnum { INSTANCE; private SingletonEnum() {} } ``` 4. **单例模式Spring结合**: - 在Spring中,`@Singleton`注解或者在配置文件中使用`singleton`属性可以自动实现单例。 相关问题-- 1. 在Spring中,如何通过XML配置实现单例模式? 2. Spring的`@Singleton`注解是如何工作的? 3. 为什么要使用枚举类型实现单例
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值