设计模式之单例模式

简介

单例模式(Singleton Pattern)是一种设计模式,其目的是确保一个类只有一个实例,并提供一个全局访问点来访问该实例。这在某些情况下非常有用,比如需要一个唯一的配置管理器、日志记录器、或资源管理器。

单例模式的特点

  1. 唯一实例:类内部维护一个唯一实例,确保类的实例只有一个。
  2. 全局访问点:提供一个全局访问点,以便其他类可以通过这个访问点获取该实例。
  3. 延迟实例化:可以延迟创建实例,直到第一次使用时才进行实例化(懒汉模式)。

实现单例模式

饿汉模式

这种方法在类加载时就创建实例,比较简单,但如果实例占用资源较大而且在实际运行中未使用,会造成资源浪费。

typescript 复制代码
class Singleton {
    private static instance: Singleton = new Singleton();
    private constructor() { }
    public static getInstance(): Singleton {
        return Singleton.instance;
    }
    public someMethod() {
        console.log('Singleton method called.');
    }
}
// 使用
const singleton = Singleton.getInstance();
singleton.someMethod();
懒汉模式

这种方法在第一次调用 getInstance 方法时才创建实例,适合需要延迟加载的情况。

typescript 复制代码
class Singleton {
    private static instance: Singleton;
    private constructor() { }
    public static getInstance(): Singleton {
        if (!Singleton.instance) {
            Singleton.instance = new Singleton();
        }
        return Singleton.instance;
    }
    public someMethod() {
        console.log('Singleton method called.');
    }
}
// 使用
const singleton = Singleton.getInstance();
singleton.someMethod();
线程安全的懒汉模式

在多线程环境中,需要确保实例创建的线程安全性。

typescript 复制代码
class Singleton {
    private static instance: Singleton;
    private static lock = new Object();
    private constructor() { }
    public static getInstance(): Singleton {
        if (!Singleton.instance) {
            synchronized (Singleton.lock) {
                if (!Singleton.instance) {
                    Singleton.instance = new Singleton();
                }
            }
        }
        return Singleton.instance;
    }
    public someMethod() {
        console.log('Singleton method called.');
    }
}

// 使用
const singleton = Singleton.getInstance();
singleton.someMethod();

单例模式的优缺点

优点:

  • 控制实例数量:确保类只有一个实例,节省资源。
  • 全局访问:提供全局访问点,方便访问实例。
  • 延迟加载:可以实现延迟加载,减少不必要的资源消耗。

缺点:

  • 扩展性差:单例类难以扩展,尤其是在需要子类化的情况下。
  • 多线程问题:在多线程环境下,需要小心处理实例创建的线程安全问题。
  • 隐藏依赖:使用单例模式可能会隐藏类之间的依赖关系,使代码难以测试和维护。
相关推荐
Aeside11 天前
揭秘 Nginx 百万并发基石:Reactor 架构与 Epoll 底层原理
后端·设计模式
蘋天纬地1 天前
蚂蚁数科二面-如果目前当前系统qps是100,如何降低成本
面试
测试界的海飞丝1 天前
14:00面试,14:06就出来了,问的问题过于变态了。。。
测试工具·面试·职场和发展
帅气的你1 天前
从零封装一个通用的 API 接口返回类:统一前后端交互格式
java·设计模式
码农水水1 天前
大疆Java面试被问:TCC事务的悬挂、空回滚问题解决方案
java·开发语言·人工智能·面试·职场和发展·单元测试·php
阿里巴巴淘系技术团队官网博客1 天前
GenAI输出内容控制的5种设计模式
设计模式
张元清1 天前
告别 Promise.all 的依赖困境:better-all 如何优雅管理异步任务
前端·javascript·面试
开源之眼1 天前
github star 加星多的从 React 到 Web3D:前端开发者的三维世界入门指南
javascript·面试
茶本无香1 天前
单例模式深度解析:饿汉式与懒汉式的实现与选择
java·单例模式
a努力。1 天前
虾皮Java面试被问:JVM Native Memory Tracking追踪堆外内存泄漏
java·开发语言·jvm·后端·python·面试