ts单例模式 | 预加载和懒加载

本文探讨了单例模式的概念,强调其限制类实例化的优点和可能导致的资源浪费。预加载单例在程序启动时即实例化,提高运行效率但可能造成资源浪费;而懒加载单例在需要时才实例化,避免启动阻塞,适用于多线程环境(尽管JavaScript是单线程)。单例的关键在于构造函数的private访问权限和静态实例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

单例模式是针对类的一种设计,让类只能有一个实例对象,对于一些没必要产生第二个实例的类来说建议设计成单例类。

单例类的实例化过程是由自身实现的,减少了其他人使用该类时的心智负担。缺点是单例类由于静态属性,无法扩展。

 

由于单例类的实例化过程是由自身实现的,所以设计的时候在new这里就会产生两种方法。

1. 预加载单例

/**
 *Singleton_quick
 *
 * @export
 * @class Singleton_quick
 */
export class Singleton_quick {
  private constructor() {}
  public static instance: Singleton_quick = new Singleton_quick()
  private _name: string
  set name(value: string) {
    this._name = value
  }
  get name(): string {
    return this._name
  }
}

程序刚开始运行,类就实例化完毕。减轻后续大量类实例化时产生的压力,提高运行流畅度。缺点是如果类比较庞大时,会使程序启动暂时阻塞,而且容易造成资源浪费,因为有些类可能并没有被调用。

2. 懒加载单例

/**
 *Singleton_lazy
 *
 * @export
 * @class Singleton_lazy
 */
export class Singleton_lazy {
  private constructor() {}
  private static instance: Singleton_lazy = null
  public static getInstance(): Singleton_lazy {
    this.instance = this.instance || new Singleton_lazy()
    return this.instance
  }
  private _name: string
  set name(value: string) {
    this._name = value
  }
  get name(): string {
    return this._name
  }
}

 类内部实现了一个getInstance方法,程序刚开始运行,类并不实例化,直到外部调用getInstance方法时才会执行构造函数,即用的时候再实例化对象。这样做可以避免程序启动刚开始时阻塞,类的所有资源采取懒加载策略。缺点是在多线程情况下会误判instance为null,然而js为单线程,不会涉及这方面的问题。

 

单例类的关键:

构造函数的访问权限为private。

静态实例。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值