单例模式

定义:

单例模式:保证一个类仅有一个实例,并提供一个访问它的全局访问点。

通常我们可以让一个全局变量使得一个对象被访问,但是它不能防止你实例化多个对象。一个最好的方法就是,让类自身负责保存它的唯一实例。这个类可以保证没有其他的实例可以被创建,并且它可以提供一个访问该实例的方法。

结构图

这里写图片描述
从结构图我们可以看出:
1.单例类中包含自己的一个静态实例(单例实例的来源,有且只有一个)
2.将构造函数变为了私有(让客户端不能创建实例,只能内部创建实例)
3.提供一个公共的静态方法得到自己的实例(类封装了控制得到实例的过程,有且只有一个入口,不会出现多个备份,内部再控制实例化的次数)

实现方式

有两种实现方法,根据实例化的时机分为“懒汉式”和“恶汉式”。

“懒汉式”,在方法调用时,如果发现没有实例化才进行实例化(但是并不是线程安全的):

public class SingletonDemo1 {
    private static SingletonDemo1 instance;
    private SingletonDemo1(){
    }
    public static SingletonDemo1 getInstance(){
        if (instance == null) {
            instance = new SingletonDemo1();
        }
        return instance;
    }
}

“饿汉式”,在定义实例时就进行实例化:

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

线程安全的”懒汉式”,双重锁定(“饿汉式”不存在线程不安全):

public class SingletonDemo3 {
    private static SingletonDemo3 instance;
    private SingletonDemo3(){}
    public static SingletonDemo3 getInstance(){
    //先判断实例是否存在,去掉实例已存在的情况
        if(instance==null){
            //加锁
            synchronized (SingletonDemo3.class) {
                //确定在等待锁的时候类没有被实例化
                if(instance ==null){
                    instance = new SingletonDemo3();
                }
            }
        }
        return instance;
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值