TypeScript实现设计模式——单例模式

最近在学习设计模式,又正好刚上手了typescript,就想要用ts实现一下试试。

单例模式的目的是限制一个类只能被实例化一次,提供一个全局的访问点。单例模式又被分为懒汉单例模式和饿汉单例模式,懒汉单例模式就是在第一次调用时实例化,饿汉单例模式是类加载时就实例化。

核心要点:

把一个静态私有变量确立为唯一的实例,外部通过静态方法访问这个唯一的实例,并把构造函数设为私有。

懒汉单例模式

class PeopleSingle {
  /**核心 - 一个接收实例的静态成员 */
  private static people: PeopleSingle;
  private name: string;

  /**核心 - 私有构造函数 */
  private constructor(name: string) {
    this.name = name;
  }

  /**核心 - 获取实例 */
  public static getInstance(): PeopleSingle {
    if (this.people == null) {
      this.people = new PeopleSingle('金闪闪');
    }
    return PeopleSingle.people;
  }

  public say(): void {
    console.log(`I'm ${this.name}.`);
  }
}

测试

let people = PeopleSingle.getInstance();
people.say();

饿汉单例模式

class PeopleSingle {
  /**核心 - 一个接收实例的静态成员,直接创建好实例 */
  private static people: PeopleSingle = new PeopleSingle('金闪闪');
  private name: string;

  /**核心 - 私有构造函数 */
  private constructor(name: string) {
    this.name = name;
  }

  /**核心 - 获取实例 */
  public static getInstance(): PeopleSingle {
    return PeopleSingle.people;
  }

  public say(): void {
    console.log(`I'm ${this.name}.`);
  }
}

测试

let people = PeopleSingle.getInstance();
people.say();

举的例子不是特别好,但是意思是这个意思。

相关文章

我最大的一个关于TypeScript的问题是,它将原型的所有方法(无...
我对React很新,我正在尝试理解子组件之间相互通信的简洁方法...
我有一个非常简单的表单,我将用户电子邮件存储在组件的状态,...
我发现接口非常有用,但由于内存问题我需要开始优化我的应用程...
我得到了一个json响应并将其存储在mongodb中,但是我不需要的...
我试图使用loadsh从以下数组中获取唯一类别,[{"listing...