• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

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

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

最近在学习设计模式,又正好刚上手了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();

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


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
被迫开始学习Typescript——class发布时间:2022-07-18
下一篇:
typescript编写react,koa2的体验发布时间:2022-07-18
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap