单例模式

本文深入探讨单例模式的实现原理及其优化方法,包括懒汉式、饿汉式和双重锁形式,旨在帮助开发者高效管理和控制类实例数量。

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

保证一个类仅有一个实例,并提供一个访问它的全局访问点。通过单例模式可以保证系统中一个类只有一个实例而且该实例易于外界访问,

从而方便对实例个数的控制并节约系统资源。如果希望在系统中某个类的对象只能存在一个,单例模式是最好的解决方案。

 

显然单例模式的要点有三个:

一是某个类只能有一个实例;

二是它必须自行创建这个实例;

三是它必须自行向整个系统提供这个实例。

 

从具体实现角度来说,就是以下三点:

一是单例模式的类只提供私有的构造函数,

二是类定义中含有一个该类的静态私有对象,

三是该类提供了一个静态的公有的函数用于创建或获取它本身的静态私有对象。

 

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

 

第一种形式:懒汉式,也是常用的形式。

public class SingletonClass{

    private static SingletonClass instance=null;

    public static SingletonClass getInstance()

    {

        if(instance==null)

        {

               instance=new SingletonClass();

        }

        return instance;

    }

    private SingletonClass(){

    }

}

 

第二种形式:饿汉式

public static class Singleton{

    //在自己内部定义自己的一个

    实例,只供内部调用

    private static final Singleton instance = new Singleton();

    private Singleton(){

        //do something

    }

    //这里提供了一个供外部访问本class的静态方法,可以直接访问

    public static Singleton getInstance(){

        return instance;

    }

}


第三种形式双重锁的形式。

public static 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;

    }

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值