Java设计模式之单例模式

单例模式应该是Java中最常见的一种设计模式。单例,顾名思义就是创建单一的实例,保证系统中一个类只创建一个实例。单例的写法有很多种,这里介绍常用的两种,懒汉式单例和饿汉式单例。
单例模式的特点:
1、这个类只能有一个实例,
2、必须自行创建这个实例。
3、必须自行向整个系统提供这个唯一的实例。
举个简单例子,打印机,比如有多台计算机连接到同一台打印机,此时应该保证同一时间只有一个计算机能够获取到打印机打印功能,否则会出现同一张纸上出现了多台计算机的内容,造成冲突。

1、饿汉式单例

public class Singleton {
    private static Singleton singleton= new Singleton();
    private Singleton(){}
    public static Singleton getSingleton(){
        return singleton;
    }
}

饿汉式单例在类创建时就实例化一个静态对象,因此占据了内存,但是第一次调用时速度更快,典型的占用空间来换更短的加载时间。

2、懒汉式单例

public class Singleton {
    private static Singleton singleton = null;
    private Singleton(){}
    public static Singleton getInstance(){
        if (singleton == null) {
            singleton = new Singleton();
        }
        return singleton;
    }
}

这是懒汉式最简单的一种写法了,实现了延时加载,因此比较“懒”,称之为懒汉式。有一个致命的弱点,线程不安全,不能用在大量并发的操作中。

public class Singleton {
    private static Singleton singleton = null;
    private Singleton(){}
    public static Singleton getInstance(){
        synchronized (Singleton.class) {
            if (singleton == null) {
                singleton = new Singleton();
            }
            return singleton;
        }
    }
}

这是已经加锁了的懒汉式单例模式,实现了线程安全,但不是最好的,因为每次调用getInstance方法都要进入synchronized中,这样可能会浪费时间,可以在外面在加上一次null判断。

public class Singleton {
    private static Singleton singleton = null;
    private Singleton(){}
    public static Singleton getInstance(){
        if (singleton == null) {
            synchronized (Singleton.class) {
                if (singleton == null){
                    singleton = new Singleton();
                }
            }
        }
        return singleton;
    }
}

这是实现了双重检查加锁。这也是用的比较多了一种,实现了线程安全,可以提交并发效率,毕竟不需要每次都进行加锁判断。
这就是Java中的单例模式,应该说简单又通俗易懂,各位看官有什么问题可以留言交流。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值