JAVA设计模式之单例模式

本文介绍了单例模式的概念及其应用场景,并详细解析了懒汉模式和饿汉模式两种常见形式。懒汉模式包括非线程安全版、线程安全版及静态内部类实现;饿汉模式在类加载时即完成实例化。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

单例模式是设计模式中经常使用的一种设计模式,单例模式确保类只能有一个实例,而且自行实例化并且向系统提供这个实例,为什么要使用单例模式,是为了避免很多时候状态不一致的情况,举一个例子,我们通常用的应用程序,只有一个主界面,我们不能同时打开两个程序的主界面。
下面介绍单例模式常见的几种形式
一.懒汉模式

/**
 * 懒汉单例模式
 * @author wst
 *
 */
public class Singleton {
    private Singleton(){

    }//私有构造方法,避免了类在外部被实例化
    private static Singleton instance=null;
    public static Singleton getInstance(){//公用的静态方法用于调用
        if(instance==null){
            instance= new Singleton();
        }
        return instance;
    }
}

这里的构造方法是私有构造方法,为了避免类在外部被实例化,但是java的反射机制同样也能够实例化private权限的构造方法,这里不对这种情况进行讨论,用反射机制,单例模式的使用可能将会失去意义。
上面的懒汉模式是不能够保证保证线程安全的,可以通过以下的一些方法实现线程的安全。
1.在getInstance方法上实现同步

public static synchronized Singleton getInstance(){
        if(instance==null){
            instance= new Singleton();
        }
        return instance;
    }

2.双重检查锁定

public static  Singleton getInstance(){
        if(instance==null){
            synchronized (Singleton.class) {
                instance=new Singleton();

            }
        }
        return instance;
    }

这里的双重锁模式不做详解,有时间我会另外写一篇博客对于双重检查锁定进行一个解释。
3.静态内部类

public class Singleton {
    private static class SingletonBuilder{
        private static final Singleton INSTANCE=new Singleton();
    }
    private Singleton(){

    }
    public static final Singleton getInstance(){
        return SingletonBuilder.INSTANCE;
    }
}

这种方式同样利用了classloder的机制来保证初始化instance时只有一个线程,这种方式是Singleton类被装载了,instance不一定被初始化。因为SingletonBuilder类没有被主动使用,只有显示通过调用getInstance方法时,才会显示装载SingletonBuilder类。相比前面两种,这种方式显得比较合理,即实现了线程安全,同时也考虑到了性能的影响。
二.饿汉模式

/**
 * 懒汉单例模式
 * @author wst
 *
 */
public class Singleton {
    private Singleton(){

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

饿汉模式在类加载的时候就进行了实例化,所以不需要考虑线程安全的问题,但是很显然没有达到延迟加载。
单例中懒汉和饿汉的本质区别在于以下几点:
  1、饿汉式是线程安全的,在类创建的同时就已经创建好一个静态的对象供系统使用,以后不在改变。懒汉式如果在创建实例对象时不加上synchronized则会导致对对象的访问不是线程安全的。
  2、从实现方式来讲他们最大的区别就是懒汉式是延时加载,他是在需要的时候才创建对象,而饿汉式在虚拟机启动的时候就会创建,饿汉式无需关注多线程问题、写法简单明了、能用则用,这是一个实例化时机的问提。
  以上就是关于单例模式的一些介绍,写几遍用几遍相信大家对于单例模式的设计思想有一定的理解。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值