关闭

设计模式之单例模式

标签: 设计模式
120人阅读 评论(0) 收藏 举报
分类:

1.定义
顾名思义,单例模式就是无论你有多少次创建,全局只能有一个该对象的实例
2.单例的几种写法
个人比较了解的有七种写法:

public class Singleton01 {

   private Singleton01(){}

   private static Singleton01 instance =new Singleton01();
    // 类被加载的时候就被初始化了,导致不必要的资源的浪费和时间的浪费

    public static Singleton01 getInstance(){
        return instance;
    }

}

public class Singleton02 {
    private Singleton02(){}
    private static Singleton02 instance;
    public static Singleton02 getInstance(){
        if(instance == null){//多线程不安全,多个线程同时访问 不能保证单例
            instance = new Singleton02();
        }
        return instance;
    }

}


public class Singleton03 {
    private Singleton03(){}

    private static Singleton03 instance;

    public synchronized static Singleton03 getInstance(){//能保证单例,但是太耗费资源,每次都要去获取整个对象的锁
        if(instance == null){
            instance = new Singleton03();
        }
        return instance;
    }

}


public class Singleton04 {//DCL

    private Singleton04(){}

    private static Singleton04 instance;

    public static Singleton04 getInstance(){
        if(instance == null){
            synchronized (Singleton04.class) {
                if(instance == null){
                    instance = new Singleton04();//出现内存的重排序  内存指向内存分配的地址,但是没有当前对象的引用,导致线程2进来时instance已经不为空
                }
            }
        }
        return instance;
    }
}

public class Singleton05 {

    private Singleton05(){}

    private volatile static Singleton05 instance;//不会出现内存重排序的,此关键字在内存中加入指令设置屏障,在写入副本时同时也刷新内存,这样导致副本和内存的数据一致

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

public class Singleton06 {
    private Singleton06(){}
    private static class InnerClass{
    private final static Singleton06 instance = new Singleton06();//内部类的实现方式,比较优雅,在想初始化的时候初始化,又能保证线程的安全,反序列化的时候不能保证单例
    }
    public static Singleton06 getInstance(){
        return InnerClass.instance;
    }
}


public enum Singleton07 {
    INSTANCE;//能够保证单例,并且在反序列化的时候也能够保证是单例的
    private A instance;
    private Singleton07(){
        instance = new A();
    }
    public A getInstance(){
        return instance;
    }
}

3.单例模式的优缺点
优点:
1.全局只有一个实例,方便管理。
2.因为全局只有一个实例,可以节约资源,对于一些频繁创建和销毁资源的对象来说,这样大大的减少了资源的消耗。
3.可以允许生命的实例数。
缺点:
1.单例模式一般没有接口或者抽象类,不方便扩展,只能在代码中修改扩展。
2.对于持有的上下文为context时,非常容易造成内存泄漏,导致资源一直被占用。建议用applcationContext。

把自己学习设计模式的过程记成笔记,方便自己随时查看,如有错误,欢迎指出,谢谢!

1
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:236次
    • 积分:39
    • 等级:
    • 排名:千里之外
    • 原创:0篇
    • 转载:0篇
    • 译文:0篇
    • 评论:0条
    文章分类
    文章存档