单例模式

参考:https://www.runoob.com/design-pattern/singleton-pattern.html

 

1、理解应用场景:保证一个类仅有一个实例,并提供一个访问它的全局访问点;

2、代码理解单例内定义的几个部分:

  • 单例类的私有实例化对象;
  • 不准外部实例化的私有构造函数;
  • 提供唯一实例的公共获取函数;

3、两种实现方式

详细参考文章,文章写的很好,这里只是概述,方便记忆。

  • 懒汉,被调用了才创建实例;
    • 又分为对外部调用方法是加锁和不加锁的(synchronized);
  • 饿汉,未雨绸缪,没被调用就生成了静态的实例;--- 线程安全
  • 双检锁/双重校验锁(DCL,即 double-checked locking) --- 线程安全

  • 静态内部类 ---  想象一下,如果实例化 instance 很消耗资源,所以想让它延迟加载,另外一方面,又不希望在 Singleton 类加载时就实例化,因为不能确保 Singleton 类还可能在其他的地方被主动使用从而被加载,那么这个时候实例化 instance 显然是不合适的。这个时候,这种方式相比第 3 种方式就显得很合理。
  • 枚举 --- 这种实现方式还没有被广泛采用,但这是实现单例模式的最佳方法。它更简洁,自动支持序列化机制,绝对防止多次实例化。这种方式是 Effective Java 作者 Josh Bloch 提倡的方式,它不仅能避免多线程同步问题,而且还自动支持序列化机制,防止反序列化重新创建新的对象,绝对防止多次实例化。不过,由于 JDK1.5 之后才加入 enum 特性,用这种方式写不免让人感觉生疏,在实际工作中,也很少用。
    不能通过 reflection attack 来调用私有构造方法。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值