JS:单例模式 —— 百度考题 (二)

简介: JS:单例模式 —— 百度考题 (二)

前言

今天我们来聊聊单例模式,在我们以往的文章中,我们讲过了代理模式,代理模式和单例模式都是设计模式的一种,感兴趣的小伙伴们可以先看看我的上篇文章,链接在此: 代理模式

设计模式是在软件设计中经常出现的一些问题的通用、可重用的解决方案。它们是经验丰富的开发人员为了解决特定类型的问题而提出的经过验证的设计思路。设计模式并不是一种可以直接的转化为代码的具体算法,而是描述问题和解决方案之间关系的抽象模型。

设计模式的主要目标是提供一种通用的、可重复使用的解决方案,帮助开发人员解决软件设计中常见的问题,提高代码的可维护性、可执行性和可扩展性。使用设计模式有助益于降低系统耦合度,使得代码更容易理解和维护。

我们先来看看上一篇文章中留下来的问题,同样它也是百度的一道考题,要求不管new 多少次, 它都只给你返回第一次创建的那唯一的一个实例,意思就是让s1 和 s2 相等。

class SingleDog{
    show() {
        console.log("我是一个单例对象");
    }
}
const s1 = new SingleDog()
const s2 = new SingleDog()
console.log(s1 === s2);

最后判断s1 === s2时会输出什么呢?

在这份代码中,s1并且s2是通过相同的类SingleDog实例化得到的,但它们实际上是两个不同的对象。因此,s1 === s2比较的结果是false

最终通过new SingleDog()创建一个新的实例时,都会产生一个新的对象。即使这两个对象的结构和方法相同,它们在内存中是不同的实体,因此对它们进行严格一致性(===)的比较时会返回false

通过这个例子我们可以看出,类创造实例对象时跟构造函数创造实例对象一样,都会产生一个新的对象。

我们知道是因为new关键字才产生了一个新的实例对象,s1、s2里面存的是地址,是不相同的,那我们怎么样才能让s1 === s2呢?

单例模式

单例模式是一种设计模式,其目的是保证一个类只有一个实例

我们可以先来想想思路,我们怎么样才可以让 s1 和 s2 拥有相同地址呢?

  • new先生成一个地址
  • 判断地址是否存在
  • 若存在,不用new,将地址赋值给对象

我们来看看代码怎么写:

class SingleDog{
    // 公共方法, 属于对象
    show(){
        console.log('我是一个单例对象');
    }
  
    // static intance
    static getInstance() {
        if (!SingleDog.instance) {
            SingleDog.instance = new SingleDog()
        }
        return SingleDog.instance
    }
}
// 类的方法
const s1 = SingleDog.getInstance()
const s2 = SingleDog.getInstance()
console.log(s1 === s2);
  • instanceSingleDog类的静态属性,存储了类的唯一实例。
  • getInstance是一个静态方法,用于获取SingleDog类的实例。在该方法内部,检查instance是否已经存在,如果不存在,则创建一个新的实例并将其赋给instance,然后返回该实例。
  • 在代码的最后,通过调用SingleDog.getInstance()获取SingleDog类的实例。由于使用了单例模式的实现,s1s2实际引用相同的实例,因此s1 === s2true

这样的设计模式保证在整个应用程序中,只有一个SingleDog实例存在,防止了多次创建相同对象的情况。

静态方法

静态方法是附加在类本身上的方法,而不是类的实例上的方法。在JavaScript中,你可以使用关键字static来定义静态方法。静态方法可以通过类名直接调用,而不需要创建类的实例,比如:const s1 = SingleDog.getInstance(),const s2 = SingleDog.getInstance()

我们来看看输出结果,使用这种方法能不能实现让s1 和 s2 拥有相同的地址

image.png

我们还有另一种方法可以实现单例模式,那就是闭包,我们之前的文章也有讲过:

class SingleDog {
    // 静态属性,用于存储单例实例
    static instance = null;
    // 静态方法,用于获取单例实例
    static getInstance() {
        if (!SingleDog.instance) {
            SingleDog.instance = new SingleDog();
        }
        return SingleDog.instance;
    }
    // 实例方法
    show() {
        console.log("我是一个单例对象");
    }
}
// 获取单例实例
const s1 = SingleDog.getInstance();
const s2 = SingleDog.getInstance();
console.log(s1 === s2); // 输出: true

因为但是内部函数引用了getInstance()外部函数的变量instance,那么instance变量依旧会被保存在内层中,所以我们可以通过判断instance是否为空来获得地址。

总结

单例模式是一种设计模式,它保证一个类只有一个实例,并提供一个全局访问点来访问这个唯一的实例。单例模式通常用于控制对资源的访问,例如配置管理、日志记录、数据库连接等。

今天的内容就到这啦,如果你觉得小编写的还不错的话,或者对你有所启发,请给小编一个辛苦的赞吧

相关文章
|
1月前
|
设计模式 JavaScript 前端开发
JS:单例模式 —— 百度考题 (一)
JS:单例模式 —— 百度考题 (一)
|
28天前
|
JavaScript 前端开发 定位技术
百度地图JavaScript API v2.0创建地图
百度地图JavaScript API v2.0创建地图
23 0
|
2月前
|
设计模式 JavaScript 前端开发
js设计模式【详解】—— 单例模式
js设计模式【详解】—— 单例模式
18 1
|
4月前
|
JavaScript 定位技术 API
[JS]百度地图设置城市
[JS]百度地图设置城市
40 1
|
4月前
|
缓存 JavaScript
js_单例模式制作无限弹窗(3s内销毁)
js_单例模式制作无限弹窗(3s内销毁)
34 0
|
4月前
|
JavaScript Ubuntu 前端开发
百度搜索:蓝易云【ubuntu安装开发javascript ubuntu script教程】
现在,你已经在Ubuntu上成功安装了JavaScript开发环境,可以开始编写和运行JavaScript代码了。注意,在编写代码之前,建议先创建一个项目文件夹,并在其中初始化npm,这样你可以管理项目的依赖项和配置。
55 5
|
4月前
|
JavaScript 关系型数据库 MySQL
百度搜索:蓝易云【Node.js写接口连接MySQL数据库教程】
现在,你的Node.js应用已经启动,可以通过访问 `http://localhost:3000/users`来获取所有用户的信息。注意替换上述代码中的数据库连接信息为你自己的实际数据。
79 0
|
2月前
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp的客户关系管理系统附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp的客户关系管理系统附带文章源码部署视频讲解等
69 2
|
2月前
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp的宠物援助平台附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp的宠物援助平台附带文章源码部署视频讲解等
62 4
|
2月前
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp的宠物交易平台附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp的宠物交易平台附带文章源码部署视频讲解等
54 4