*单例模式:
确保某一个类只有一个实例,而且自行实例化并向整个系统提供这个实例,这个类称为单例模式,它提供全局访问的方法。*
饿汉式单例:
饿汉式单例,指全局的单例实例在类装载时构建。
废话不多说,看栗子
public class Singleton {
private final static Singleton INSTANCE = new Singleton();
// Private constructor suppresses
private Singleton() {}
// default public constructor
public static Singleton getInstance() {
return INSTANCE;
}
}
懒汉式单例:
懒汉方式,指全局的单例实例在第一次被使用时构建。
public class Singleton {
private static volatile Singleton INSTANCE = null;
// Private constructor suppresses
// default public constructor
private Singleton() {}
//thread safe and performance promote
public static Singleton getInstance() {
if(INSTANCE == null){
synchronized(Singleton.class){
//when more than two threads run into the first null check same time, to avoid instanced more than one time, it needs to be checked again.
if(INSTANCE == null){
INSTANCE = new Singleton();
}
}
}
return INSTANCE;
}
}
一种更好的单例实现方法
饿汉式单例类不能实现延迟加载,不管将来用不用,它始终占据内存;懒汉式单例线程安全控制繁琐,而且性能受影响。Initialization Demand Holder (IoDH)技术克服二者缺点,综合二者优点。
主要使用到了静态内部类
//Initialization on Demand Holder
class Singleton {
private Singleton() {
}
private static class HolderClass {
private final static Singleton instance = new Singleton();
}
public static Singleton getInstance() {
return HolderClass.instance;
}
public static void main(String args[]) {
Singleton s1, s2;
s1 = Singleton.getInstance();
s2 = Singleton.getInstance();
System.out.println(s1==s2);
}
}
涨姿势环节
单例模式总结:
一、主要优点:
1. 单例模式提供了对唯一实例的受控制访问。
2. 在系统内存中只存在一个对象,节约了系统资源,对于频繁创建和销毁的对象,单例模 式可以提高系统的性能。
3. 允许课变数目的实例。
二、主要缺点:
1. 单例模式没有抽象层,因此单例模式扩展困难。
2. 单例类的职责过重,在一定程度上违背了单一职责原则。
3. 许多面对对象语言(如java、C#)的运行环境提供了自动垃圾回收技术,实例化的对 象长期不使用,会被系统回收,重新实例化的对象会失去之前的状态。
三、使用场景
1. 系统只需要一个实例对象。
2. 客户端用类调用的单个实例只允许使用一个公共访问点,除此之外,无其他途径访问该实例。