package com.young.singleton.type7;
/**
* @author Shaw_Young
* @date 2020/09/03 13:43
*/
public class SingletonTest07 {
public static void main(String[] args) {
System.out.println("使用静态内部类完成单例模式");
Singleton instance1 = Singleton.getInstance();
Singleton instance2 = Singleton.getInstance();
System.out.println(instance1 == instance2);
System.out.println(instance1.hashCode());
System.out.println(instance2.hashCode());
}
}
/**
* 静态内部类完成,推荐使用
*/
class Singleton {
/**
* 构造器私有化
*/
private Singleton() {
}
/**
* 写一个静态内部类,该类中有一个静态属性 Singleton
*/
private static class SingletonInstance {
private static final Singleton INSTANCE = new Singleton();
}
/**
* 提供一个静态的公有方法,直接返回SingletonInstance.INSTANCE
*/
static Singleton getInstance() {
return SingletonInstance.INSTANCE;
}
}
优缺点说明:
- 这种方式采用了类装载的机制来保证初始化实例时只有一个线程。
- 静态内部类方式在Singleton类被装载时并不会实例化,而是在需要实例化时,调用getInstance方法,才会装载SingletonInstance类,从而完成Singleton的实例化。
- 类的静态属性只会在第一次加载类的时候初始化,所以在这里,JVM帮助我们保证了线程的安全性,在类进行初始化时,别的线程是无法进入的。
- 优点: 避免了线程不安全,利用静态内部类特点实现延迟加载,效率高。
- 结论: 推荐使用。