单例设计模式介绍
所谓类的单例设计模式,就是采取一定的方法保证在整个的软件系统中,对某个类只能存在一个对象实例,并且该类只提供一个取得其对象实例的方法(静态方法)。
比如Hibernate的SessionFactory,它充当数据存储源的代理,并负责创建Session对象。SessionFactory并不是轻量级的,一般情况下,一个项目通常只需要一个SessionFactory就够,这是就会使用到单例模式。
单例设计模式八种方式
饿汉式(静态常量)饿汉式(静态代码块)- 懒汉式(线程不安全)
- 懒汉式(线程安全,同步方法)
- 懒汉式(线程安全,同步代码块)
双重检查静态内部类枚举
饿汉式(静态常量)
饿汉式(静态常量)应用实例
步骤如下:
- 构造器私有化。
- 类的内部创建对象。
- 向外暴露一个静态的公共方法。
- 代码实现
/**
* @author Shaw_Young
* @date 2020/7/5 15:24
*/
public class SingletonTest01 {
public static void main(String[] args) {
Singleton instance1 = Singleton.getInstance();
Singleton instance2 = Singleton.getInstance();
Singleton instance3 = Singleton.getInstance();
System.out.println(instance1 == instance2);
System.out.println(instance1.hashCode());
System.out.println(instance2.hashCode());
System.out.println(instance3.hashCode());
}
}
//饿汉式(静态变量)
class Singleton {
//1.构造器私有化,外部不能new
private Singleton() {
}
//2.本类内部创建一个对象实例
private final static Singleton instance = new Singleton();
//3.提供一个公有的静态方法,返回实例对象
public static Singleton getInstance() {
return instance;
}
}
优缺点说明:
- 优点: 这种写法比较简单,就是在类装载的时候就会完成实例化。避免了线程同步问题。
- 缺点: 在类装载的时候就完成实例化,没有达到Lazy Loading的效果。如果从始至终从未使用这个实例,则会造成内存的浪费。
- 这种方式基于classLoader机制避免了多线程的同步问题,不过,instance在类装载时就实例化,在单例模式中大多数都是调用getInstance方法,但是导致类装载的原因有很多种,因此不能确定有其他的方式(或者其他的静态方法)导致类装载,这时候初始化instance就没有达到lazy loading的效果。
- 结论: 这种单例模式可用,
可能造成内存浪费。