设计模式之单例模式

**单例模式:

就是只有一个实例**,并且它自己负责创建自己的对象,这个类提供了一种访问其唯一对象的方式,可以是直接访问,不需要实例化该类的对象。一个类只能构建一个对象的模式。
核心代码就是:构造方法私有化**

1 懒汉模式

用的时候才去检查有没有实例,如果有则返回,没有则新建

public class Singleton {
    private Singleton(){} //私有构造函数
     private static Singleton instance = null; //单例对象
    public static Singleton getInstance(){
        if (instance == null)       
                instance = new Singleton();            
        }
        return instance;
    }
}

1.要想让一个类只能构建一个对象,自然不能让它随便去做new操作,因此Signleton的构造方法是私有的
2 getInstance是获取单例对象的方法

2 饿汉模式

实例在初始化的时候就已经建好了,不管你有没有用到,都先建好了再说。好处是没有线程安全的问题,坏处是浪费内存空间。


public class Singleton {
    private Singleton(){}
     private  static Singleton instance = new Singleton();
    public static Singleton getInstance(){
        return instance;
    }
}

双重检测

 private Singleton(){}
    private volatile static Singleton instance = null;
    public static Singleton getInstance(){
        if (instance == null){  //双重检测机制
            synchronized (Singleton.class){//同步锁
                if (instance == null){  //双重检测机制
                    instance = new Singleton();
                }
            }
        }
        return instance;
    }

使用volatile保证禁止重排序

用静态内部类实现单例模式:

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

外部无法访问静态内部类LazyHolder,只有当调用Singleton.getInstance方法的时候,才能得到单例对象INSTANCE。
INSTANCE对象初始化的时机并不是在单例类Singleton被加载的时候,而是在调用getInstance方法,使得静态内部类LazyHolder被加载的时候。因此这种实现方式是利用classloader的加载机制来实现懒加载,并保证构建单例的线程安全。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值