单例模式--懒汉 饿汉模式

一.啥是单例模式?

先介绍一下设计模式:

设计模式好⽐象棋中的 "棋谱". 红⽅当头炮, ⿊⽅⻢来跳. 针对红⽅的⼀些⾛法, ⿊⽅应招的时候有⼀些固定的套路. 按照套路来⾛局势就不会吃亏.
软件开发中也有很多常⻅的 "问题场景". 针对这些问题场景, ⼤佬们总结出了⼀些固定的套路. 按照这个套路来实现代码, 也不会吃亏.

单例模式能保证某个类在程序中只存在唯⼀⼀份实例, ⽽不会创建出多个实例.

这种情况就存在了两份实例

单例模式具体的实现⽅式有很多. 最常⻅的是 "饿汉" 和 "懒汉" 两种

二.饿汉模式

实现步骤:

1.要实现单例模式,只需要定义一个静态全局变量,这样就可以保证变量全局唯一。

复制代码
private static Singleton instance= new Singleton();

private:保证这个变量不可修改。

static:保证全局唯一

2.构造方法私有化

复制代码
private Singleton() {
    }

这样就保证了外界无法通过构造方法创建对象

3.将获取instance的方法用static修饰,使其可以通过类.方法名调用。

复制代码
public static Singleton getInstance() {
        return instance;
    }

public class Singleton {
    private static Singleton instance= new Singleton();
    //构造方法私有化
    private Singleton() {
    }
    public static Singleton getInstance() {
        return instance;
    }
}

这种在类加载时就完成初始化对象的模式称为"饿汉模式"。

三.懒汉模式

1.只声明全局变量,不初始化

复制代码
​​​​​​​private static Singleton_02 instance = null;

2.获取instance时进行if判断,为null再初始化

复制代码
public static Singleton_02 getInstance() {
          if(instance == null) {
             instance = new Singleton_02();
          }
     return instance;
 }

private static Singleton_02 instance = null;
    private Singleton_02() {

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

这样创建在单线程运行没问题

但在多线程模式下:

这里暂停1s是为了让线程全部进入if语句

可能会出现问题

因此,要解决这个线程问题,使用新学的synchronized,volatile关键字

复制代码
private static volatile Singleton_02 instance = null;
    private Singleton_02() {

    }
    public static Singleton_02 getInstance() {
        if(instance == null) {
            synchronized(Singleton_02.class) {
                if(instance == null) {
                    instance = new Singleton_02();
                }
            }
        }
        return instance;
    }
相关推荐
CoderLiu14 分钟前
用这个MCP,只给大模型一个figma链接就能直接导出图片,还能自动压缩上传?
前端·llm·mcp
伍哥的传说16 分钟前
鸿蒙系统(HarmonyOS)应用开发之实现电子签名效果
开发语言·前端·华为·harmonyos·鸿蒙·鸿蒙系统
海的诗篇_1 小时前
前端开发面试题总结-原生小程序部分
前端·javascript·面试·小程序·vue·html
uncleTom6661 小时前
前端地图可视化的新宠儿:Cesium 地图封装实践
前端
lemonzoey1 小时前
无缝集成 gemini-cli 的 vscode 插件:shenma
前端·人工智能
老家的回忆1 小时前
jsPDF和html2canvas生成pdf,组件用的elementplus,亲测30多页,20s实现
前端·vue.js·pdf·html2canvas·jspdf
半点寒12W1 小时前
uniapp全局状态管理实现方案
前端
Vertira1 小时前
pdf 合并 python实现(已解决)
前端·python·pdf
PeterJXL2 小时前
Chrome 下载文件时总是提示“已阻止不安全的下载”的解决方案
前端·chrome·安全
hackchen2 小时前
从0到1解锁Element-Plus组件二次封装El-Dialog动态调用
前端·vue.js·elementui