单例模式

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);
    }
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

友情链接更多精彩内容