设计模式之单例模式(Singleton)

总体来说设计模式分为三大类:
创建型模式5种:工厂方法模式、抽象工厂模式、单例模式、建造者模式、原型模式。
结构型模式7种:适配器模式、装饰器模式、代理模式、外观模式、桥接模式、组合模式、享元模式。
行为型模式11种:策略模式、模板方法模式、观察者模式、迭代子模式、责任链模式、命令模式、备忘录模式、状态模式、访问者模式、中介者模式、解释器模式。

单例模式

Java中单例模式定义:“一个类有且仅有一个实例,并且自行实例化向整个系统提供。”

Demo

一般Singleton模式通常有三种形式:

第一种形式:懒汉式,也是常用的形式
public class SingletonClass{
    private static SingletonClass instance=null;
    public static synchronized SingletonClass getInstance()
    {
        if(instance==null)
        {
               instance=new SingletonClass();
        }
        return instance;
    }
    private SingletonClass(){
    }
}
第二种形式:饿汉式
public class Singleton{

    private static final Singleton instance = new Singleton();  //在自己内部定义自己的一个实例,只供内部调用
    private Singleton(){
        //do something
    }

    public static Singleton getInstance(){ //这里提供了一个供外部访问本class的静态方法,可以直接访问
        return instance;
    }
}
对第一行static的一些解释
java允许我们在一个类里面定义静态类。比如内部类(nested class)。
把nested class封闭起来的类叫外部类。
在java中,我们不能用static修饰顶级类(top level class)。
只有内部类可以为static。
第三种形式: 双重锁的形式。
public class Singleton{
    private static Singleton instance=null;
    private Singleton(){
        //do something
    }
    public static Singleton getInstance(){
        if(instance==null){
            synchronized(Singleton.class){
                if(null==instance){
                    instance=new Singleton();
                }
            }
        }
        return instance;
这个模式将同步内容下方到if内部,提高了执行的效率,不必每次获取对象时都进行同步,只有第一次才同步,创建了以后就没必要了。
总结一个比较完美的单例模式
public class Singleton {


    private Singleton() {// 私有构造方法,防止被实例化 
    }

    private static class SingletonFactory {//此处使用一个内部类来维护单例
        private static Singleton instance = new Singleton();
    }

    public static Singleton getInstance() {// 获取实例
        return SingletonFactory.instance;
    }

    public Object readResolve() {// 如果该对象被用于序列化,可以保证对象在序列化前后保持一致
        return getInstance();
    }
}

优缺点

优点

①实例控制
单例模式会阻止其他对象实例化其自己的单例对象的副本,从而确保所有对象都访问唯一实例。
②灵活性
因为类控制了实例化过程,所以类可以灵活更改实例化过程。

缺点

①开销

虽然数量很少,但如果每次对象请求引用时都要检查是否存在类的实例,将仍然需要一些开销。可以通过使用静态初始化解决此问题。

②可能的开发混淆
使用单例对象(尤其在类库中定义的对象)时,开发人员必须记住自己不能使用new关键字实例化对象。因为可能无法访问库源代码,因此应用程序开发人员可能会意外发现自己无法直接实例化此类。
③对象生存期
不能解决删除单个对象的问题。在提供内存管理的语言中(例如基于.NET Framework的语言),只有单例类能够导致实例被取消分配,因为它包含对该实例的私有引用。在某些语言中(如 C++),其他类可以删除对象实例,但这样会导致单例类中出现悬浮引用。
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值