设计模式——单例模式
一、什么是单例模式?
单例模式(Slingleton Pattern)在设计模式中属于创建型模式。该模式涉及到一个单一的类,这个类负责创建自己的实力对象,同时确保只有单个实例对象被创建,即一个类只有一个实例对象。
二、实现方式
1、懒汉式(线程不安全)
这是最基本的实现方式,但因为没有synchronize,线程不安全,在多线程不能正常工作
private static Singleton instance;
private Singleton(){
}
public static Singleton getInstance(){
if (instance == null) {
instance = new Singleton();
}
return instance;
2、懒汉式(线程安全)
第一次调用才初始化,避免了内存浪费;保证了线程安全,但加锁影响效率
private static Singleton instance;
// 私有构造函数
private Singleton(){
}
public static synchronized Singleton getInstance(){
if (instance == null) {
instance = new Singleton();
}
return instance;
3、饿汉式
没有加锁,执行效率会提高;比较常用,但在加载时就初始化会浪费内存
private static Singleton instance = new Singleton();
private Singleton(){
}
public static Singleton getInstance(){
return instance;
4、双重校验锁
安全且在多线程情况下能保持高性能
注意:
volatile,它可以禁止指令重排序能确保instance变量在多线程环境中被正确地初始化。保证了在多线程环境下单例的唯一性。
private volatile static Singleton singleton;
private Singleton(){}
public static Singleton getInstance(){
if (singleton == null){
synchronized (Singleton.class){
if (singleton == null){
singleton = new Singleton();
}
}
}
return singleton;
三、注意事项
- 饿汉式单例类加载时就初始化了,所以类加载慢,但获取对象的速度快;
- 懒汉式单例在第一次调用getInstance()时初始化,类加载快,但第一次获取对象慢。在多线程环境下,懒汉式单例如果不加同步措施会不安全,所以需要使用synchronized关键字或volatile关键字来确保线程安全;
- 双重检查锁定(DCL)是在懒汉式单例的基础上做的一种优化,可以提高性能,但实现上需要特别注意volatile关键字的使用,以避免指令重排序导致的问题。