单例模式就是用于确保系统只能产生一个实例对象,不会出现创建多个实例对象的情况
1. 饿汉式单例
代码:
public class Singleton {
private Singleton() {
}
private static Singleton instance = new Singleton();
public static Singleton getInstance(){
return instance;
}
}
以上需要注意: 构造方法需要private 进行修饰, 防止外部被创建; 每次调用getInstance()方法时即创建Singleton实例,
这种方式的性能是非常好的, 在高并发下也能不会存在安全问题, 而且没有采用任何的锁设计, 提升性能
2. 懒汉式单例
public class Singleton { private Singleton() { } private static Singleton instance = null; public static Singleton getInstance() { // 延迟加载策略, 最初并不会实例化instance 只有调用getInstance()方法时才会进行实例化 if (instance == null) { instance = new Singleton(); } return instance; } }
为了防止对象被多次创建需要synchronized 加锁进行处理, 对性能有影响
结合二者有点推出下面的方式:
3.终极模式(推荐)
public class Singleton { private Singleton() { } // 内部类 private static class SingletonHolder{ private static Singleton instance = new Singleton(); } public static Singleton getInstance() { return SingletonHolder.instance; } }
说明: 以上巧妙使用了内部类和类的初始化方式, 内部类SingletonHolder 生命为private 外界不能访问 , 只能通过getInstance()方法内部
对SingletonHolder类进行初始化, 利用虚拟机的类初始化机制创建实例对象.