TS 设计模式03 - 单例模式
时间:2022-07-22
本文章向大家介绍TS 设计模式03 - 单例模式,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
1. 简介
单例模式的概念很简单,就是在整个程序中有且仅有一个实例。这种场景其实是很常见的,比如我们的程序中存放当前用户信息的类,就只有一个实例,这样从任何地方获取其中信息时,都是拿的同一个对象的信息,保证状态的一致性。
2. 饿汉式
在该类创建的时候就进行了实例化。
class Singleton {
private name: string;
private static instance: Singleton = new Singleton('singleton');
private constructor(name: string) {
this.name = name;
// TODO 初始化逻辑
}
public static getInstance(): Singleton {
return Singleton.instance;
}
show() {
console.log(this.name);
}
}
Singleton.getInstance().show(); // singleton
3. 懒汉式
在真正调用 getInstance 方法时,类才被真正实例化,更加节约空间。
class Singleton {
constructor(name) {
this.name = name;
// TODO 初始化逻辑
}
static getInstance() {
if (!Singleton.instance) {
Singleton.instance = new Singleton('singleton');
}
return Singleton.instance;
}
show() {
console.log(this.name);
}
}
Singleton.getInstance().show(); // singleton
4. 模块化实现
其实真正在项目中使用时,因为我们都是用模块化编程,只需要模块抛出的是一个实例而不是类,那么一样能达到单例效果。单例是在模块被引入的时候进行实例化的,模块本身其实是可以直接导入或者使用懒加载的。
// export.ts
class Singleton {
protected name: string;
constructor(name) {
this.name = name;
// TODO 初始化逻辑
}
show() {
console.log(this.name);
}
}
export default new Singleton('singleton');
// import.ts
import singleton from './export';
singleton.show();
5.小结
其实单例的核心,就是全局共享一个实例。
- WCF技术剖析之二十八:自己动手获取元数据[附源代码下载]
- 微信年度重磅“小游戏”上线,罗胖一度退出的小程序正在逆袭
- 谈谈WCF中的Data Contract(2):WCF Data Contract对Generic的支持
- Android注解学习(1)
- [WCF权限控制]ASP.NET Roles授权[上篇]
- [WCF权限控制]ASP.NET Roles授权[下篇]
- 如何解决分布式系统中的跨时区问题[实例篇]
- Visual Studio对程序集签名时一个很不好用的地方
- 一个关于解决序列化问题的编程技巧
- [WCF权限控制]从两个重要的概念谈起:Identity与Principal[上篇]
- 从数据到代码——通过代码生成机制实现强类型编程[下篇]
- 谈谈你最熟悉的System.DateTime[下篇]
- 如何解决EnterLib异常处理框架最大的局限——基于异常"类型"的异常处理策略
- [WCF权限控制]从两个重要的概念谈起:Identity与Principal[下篇]
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 用 Tensorflow 实现简单多层神经网络
- Tensorflow 命名空间与计算图可视化
- Tensorboard 高维向量可视化
- 在K3s上使用Kong网关插件,开启K3s的无限可能!
- 在线教育平台开发中,作业功能中的图片上传是如何实现的
- java基本数据类型
- java基础语法
- java对象和类
- python中使用马尔可夫决策过程(MDP)动态编程来解决最短路径强化学习问题
- 《剑指 offer》刷题记录之:数组
- R语言中绘制箱形图的替代品:蜂群图和小提琴图
- 《剑指 offer》刷题记录之:字符串 & 链表
- python中使用马尔可夫决策过程(MDP)动态编程来解决最短路径强化学习问题
- 《剑指 offer》刷题记录之:树 & 栈和队列
- R语言自定义两种统计量度:平均值和中位数,何时去使用?