前端开发设计模式——单例模式

ops/2025/3/19 23:24:56/

目录

一、单例模式的定义和特点:

        1.定义:

        2.特点:

二、单例模式的实现方式:

        1.立即执行函数结合闭包实现:

        2.ES6类实现:

三、单例模式的应用场景

        1.全局状态管理:

        2.日志记录器:

        3.数据库连接:

四、单例模式的优点

        1.减少资源消耗:

        2.全局访问:

        3.易于管理:

五、单例模式的缺点

        1.测试困难:

        2.违法单一职责原则:

        3.可能导致内存泄漏:

六、单例模式的注意事项

        1.线程安全:

        2.延迟加载:

        3.可扩展性:


        在前端开发中,单例模式是一种常用的设计模式,它确保一个类只有一个实例,并提供一个全局访问点。以下是对单例模式的深入讲解:

一、单例模式的定义和特点:

        1.定义:

                单例模式是一种创建型设计模式,它保证一个类只有一个示例,并提供一个访问它的全局访问点。

        2.特点:

                唯一性:单例模式只有一个实例,无论在程序的任何地方访问这个类,都将得到同一个实例。

                全局访问:提供了一种全局访问该实例的方式,使得在整个程序中都可以方便地使用这个唯一的实例。

二、单例模式的实现方式:

        1.立即执行函数结合闭包实现:

                在 JavaScript 中,可以使用立即执行函数(Immediately Invoked Function Expression,IIFE)结合闭包来实现单例模式

                例如:

javascript">   const Singleton = (function () {let instance;function createInstance() {return new Object("I am the single instance.");}return {getInstance: function () {if (!instance) {instance = createInstance();}return instance;},};})();

                在这个例子中,立即执行函数返回一个包含getInstance方法的对象。getInstance方法在第一次调用时创建实例,并在后续调用中返回这个唯一的实例。

        2.ES6类实现:

                使用ES6类语法也可以实现单例模式

                例如:

javascript">   class Singleton {constructor() {if (!Singleton.instance) {Singleton.instance = this;}return Singleton.instance;}}

                在这个例子中,构造函数在第一次创建实例时将实例存储在类的静态属性上,并在后续调用中返回这个实例。

三、单例模式的应用场景

        1.全局状态管理:

                在前端应用中,可能需要一个全局的状态管理器来存储和管理应用的状态。使用单例模式可以确保只有一个状态管理器实例,避免状态的混乱和不一致。

                例如,使用 Redux 或 Vuex 进行状态管理时,它们的 store 就是一个单例对象,在整个应用中只有一个实例,用于存储和管理应用的状态。

        2.日志记录器:

                日志记录器通常需要在整个应用中共享,以便在不同的地方记录日志。使用单例模式可以确保只有一个日志记录器实例,方便进行日志的统一管理和输出。

                例如,可以创建一个单例的日志记录器对象,提供方法来记录不同级别的日志信息,并将日志输出到控制台或文件中。

        3.数据库连接:

                在与数据库进行交互时,通常需要建立数据库连接。使用单例模式可以确保只有一个数据库连接实例,避免重复建立连接带来的资源浪费和性能问题。

                例如,可以创建一个单例的数据库连接对象,提供方法来执行数据库查询和更新操作,并在应用启动时建立连接,在应用关闭时关闭连接。

四、单例模式的优点

        1.减少资源消耗:

                对于一些需要频繁创建但又只需一个实例的对象,如全局状态管理、日志记录器等,使用单例模式可以避免重复创建对象带来的资源浪费。

        2.全局访问:

                提供了一个简单的方式来访问唯一的实例,方便在不同的模块中使用。

        3.易于管理:

                由于只有一个实例,对于一些需要统一管理的对象,如配置对象、全局缓存等,使用单例模式可以方便地进行管理和维护。

五、单例模式的缺点

        1.测试困难:

                由于单例通常是全局可访问的,这使得在单元测试中难以模拟和控制其行为,可能会导致测试的复杂性增加。

        2.违法单一职责原则:

                单例对象可能承担过多的职责,不利于代码的可维护性和扩展性。

        3.可能导致内存泄漏:

                如果单例对象在整个应用的生命周期中都存在,并且持有一些资源(如数据库连接、文件句柄等),如果不及时释放这些资源,可能会导致内存泄漏。

六、单例模式的注意事项

        1.线程安全:

                在多线程环境下,需要确保单例的创建是线程安全的。可以使用锁或其他同步机制来保证在多个线程同时访问单例时,只有一个实例被创建。

        2.延迟加载:

                可以考虑使用延迟加载的方式来创建单例实例,即在第一次访问单例时才创建实例。这样可以避免在应用启动时就创建一些可能不需要的对象,提高应用的启动速度。

        3.可扩展性:

                在设计单例类时,要考虑到未来可能的扩展需求。尽量保持单例类的接口简洁和可扩展,以便在需要时可以方便地添加新的功能。

        对于前端开发设计模式中的单例模式就分享到这,如果对设计模式中的其他模式有兴趣的话,可以点开主页看看相关文章。码字不易,点个赞再走吧


http://www.ppmy.cn/ops/121671.html

相关文章

【C++算法】10.滑动窗口_长度最小的子数组

文章目录 题目链接:题目描述:解法C 算法代码:图解 题目链接: 209. 长度最小的子数组 题目描述: 解法 解法一:暴力求解(会超时) 暴力枚举出所有子数组的和。 查找子数组n2&#xff0…

TryHackMe 第6天 | Web Fundamentals (一)

这一部分我们要简要介绍以下 Web Hacking 的基本内容,预计分三次博客。 在访问 Web 应用时,浏览器提供了若干个工具来帮助我们发现一些潜在问题和有用的信息。 比如可以查看网站源代码。查看源代码可以 右键 网页,然后选择 查看网站源代码&…

Pikachu-xss防范措施 - href输出 js输出

总体原则: 输入做过滤,输出做转义 过滤:根据业务需要进行过滤,如:输入点要求输入手机号,则只允许输入手机号格式的数字; 转义:所有输出到前端的数据,都根据输出点进行转…

第33次CCF计算机软件能力认证【T1~T3】:词频统计、相似度计算、化学方程式配平

题目概括词频统计枚举相似度计算STL工具(tranform()转换大小写) 模拟化学方程式配平大模拟高斯消元 1、词频统计 在学习了文本处理后,小 P 对英语书中的 n 篇文章进行了初步整理。 具体来说,小 P 将所有的英文单词都转化为了整数…

IDEA使用技巧

在使用IntelliJ IDEA(简称IDEA)这类集成开发环境(IDE)时,掌握一些高效的使用技巧和安装合适的插件可以显著提升开发效率。以下将从IDEA的使用技巧和插件推荐两个方面进行详细阐述。 一、IDEA使用技巧 1. 快捷键操作 …

Flink源码剖析

写在前面 最近一段时间都没有更新博客了,原因有点离谱,在实现flink的两阶段提交的时候,每次执行自定义的notifyCheckpointComplete时候,好像就会停止消费数据,完成notifyComplete后再消费数据;基于上述原因…

79. 单词搜索

思路 每次以当前位置为初始位置开始遍历,看是否找到单词 (以官方题解做出) v:代表等于work[k]且已走过的位置 d:四个方向 回溯(遍历): 匹配不上:终止 找到了:终止(先…

C++11中智能指针以及标准模板库 My_string My_stack

My_string.h #ifndef MY_STRING_H #define MY_STRING_H#include <iostream> #include <cstring> #include <stdexcept>using namespace std;template<typename T> class My_string { private:T *ptr; // 指向字符数组的指针int size; /…