单例模式

2018-10-18  本文已影响0人  sindorina
public class Singleton {
    /**
     * 必须防止外部可以调用构造函数进行实例化,因此构造函数必须私有化。
     必须定义一个静态函数获得该单例
     单例使用volatile修饰
     使用synchronized 进行同步处理,并且双重判断是否为null,
     我们看到synchronized (Singleton.class)里面又进行了是否为null的判断,
     这是因为一个线程进入了该代码,如果另一个线程在等待,
     这时候前一个线程创建了一个实例出来完毕后,
     另一个线程获得锁进入该同步代码,实例已经存在,没必要再次创建,因此这个判断是否是null还是必须的
     */
    private static volatile Singleton instance = null;

    private Singleton() {

    }

    public static Singleton getInstance(){
        if (instance == null){
            synchronized (Singleton.class){
                if (instance == null){
                    instance = new Singleton();
                }
            }
        }
        return instance;
    }
}

静态内部类实现

public class Singleton {
    private Singleton(){
        
    }
    public static Singleton getInstance(){
        return SingletonHolder.INSTANCE;
    }
    private static class SingletonHolder{
        private static final Singleton INSTANCE = new Singleton();
    }
}

单例容器

public class SingletonManager {
    private static final Map<String,Object> SERVICE_MAP = new HashMap<>();

    private SingletonManager() {
    }

    public static void registerService(String service, Object object){
        if (!SERVICE_MAP.containsKey(service)){
            SERVICE_MAP.put(service,object);
        }
    }

    public static Object getService(String service){
        return SERVICE_MAP.get(service);
    }
}
上一篇 下一篇

猜你喜欢

热点阅读