单例模式

本文介绍了单例模式的概念及其重要性,详细讨论了单例模式的五种实现方式:饿汉式、懒汉式、双检锁、静态内部类和枚举。针对双检锁存在的线程安全问题,文章分析了问题原因并提出了三种解决方案。最后,推荐使用枚举方式实现单例,因为它既保证了线程安全,又避免了反射和序列化攻击的风险。
摘要由CSDN通过智能技术生成

单例模式

单例模式, 顾名思义就是只有一个实例, 并且它自己负责创建自己的对象, 这个类提供了一种访问其唯一的对象的形式. 可以直接访问, 不需要实例化该类的对象.


单例模式的几种形式

饿汉式

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

实例在类初始化的时候就创建好了, 不管你有没有用到. 好处是没有线程安全问题, 坏处是比较浪费内存空间.


懒汉式

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

懒汉式, 顾名思义就是实例在用到的时候才去创建.
有线程安全和不安全两种写法, 区别就是synchronized关键字


双检锁

class Singleton {
   
    private Singleton() {
    }
    private static Singleton instance;
    public static Singleton newInstance() {
   
        if (instance == null) {
   		// 第一次检查, 有则返回  (此时尚未加锁, 可以提高效率)
			   synchronized(Singleton.class) {
   
					if (instance == null) {
   		// 第二次检查, 再获取到锁之间, 再次检查是为完成初始化
						instance = new Singleton();
					}
			   }
        }
        return instance;
    }
}

双检锁, 又叫双重校验

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值