单例模式与适配器模式

单例模式
定义:确保一个类只有一个实例,并提供一个全局访问点来访问这个唯一实例
角色:Singleton(单例)
结构图:单例模式代码实现:

public class Singleton {
    private static Singleton instance =null;
    private Singleton(){
        
    }
    public static Singleton getInstance(){
        if(instance==null)
            instance=new Singleton();
        return instance;
    }
}

优点:
1、单例模式提供了对唯一实例的受控访问。
2、由于在系统内存中只存在一个对象,因此可以节约系统资源。
3、允许可变树木的实例
缺点:
1、没有抽象层,扩展有很大困难
2、职责过重,在一定程度上违背了单一职责原则
3、如果实例化对象长时间不被利用,系统会认为他是垃圾,会自动销毁并回收资源下次利用又将重新实例化,这将导致共享的单例对象状态丢失
适配器模式
定义:讲一个类的接口转换成客户希望的另一个接口,适配器模式让那些接口不兼容的类可以一起工作
角色:
1)Target(目标抽象类)2)Adapter(适配器类)3)Adaptee(适配者类)
结构图:在这里插入图片描述代码实现:
CarController:汽车控制类,充当目标抽象类

//designpatterns.adapter.CarController.java
package designpatterns.adapter
public abstract class CarController{
    public void move(){
        System.out.println("玩具汽车移动!");
    }
    public abstract void phonate();//发出声音
    public abstract void twinkle();//灯光闪烁
}

优点:
1、将目标类和适配者类解耦,通过引入一个适配器来重用现有的适配器类,无须修改原有结构
2、增加类的透明性和复用性,将具体的业务实现过程封装在适配者类中,对于客户端类而言是透明的,而且提高了适配者的复用性,同一个适配者类可以再多个不同的系统中复用。
3、灵活性和扩展性都非常好,通过使用配置文件可以很方便的更换适配器,也可以在不修改原有代码的基础上增加新的适配器类,完全符合开闭原则
缺点:
1、对于不支持多重类继承的语言,一次最多只能配置一个适配者类,不能同时适配多个适配者
2、适配者类不能最为最终类
3、在java等语言中,类适配器模式模式中的目标抽象类只能为接口,不能为类,其使用有一定局限

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
NodeJS单例模式是一种设计模式,它保证一个类仅有一个实例,并提供一个全局访问点。这种模式解决了多个实例共享相同状态的问题。在NodeJS中,可以使用单例模式来管理全局的资源或配置,以确保在应用程序中只有一个实例被创建和访问。 要实现NodeJS单例模式,可以使用以下步骤: 1. 创建一个类,例如Single,该类拥有一个私有静态属性instance,用于存储单例实例。 2. 在Single类中定义一个静态方法getInstance,用于获取单例实例。在这个方法中,检查instance属性是否已经存在,如果存在则返回它,否则创建一个新的实例并将其赋值给instance。 3. 在需要使用单例的地方,通过调用Single.getInstance()方法来获取单例实例。 下面是一个示例代码: ``` // single_class.js class Single { constructor(date) { this.date = date; } show() { console.log('This is a single instance created on ' + this.date); } static getInstance() { if (!Single.instance) { Single.instance = new Single(); } return Single.instance; } } module.exports = Single; ``` 在上面的代码中,Single类具有一个私有静态属性instance,用于存储单例实例。getInstance方法检查instance属性是否已存在,如果不存在则创建一个新的实例并将其赋值给instance,最后返回instance。通过使用require引入Single类,并可以通过Single.getInstance()方法来获取单例实例。 例如,在single_app.js中: ``` // single_app.js var Single = require('./single_class'); var singleObj1 = new Single('2012-11-10'); var singleClass1 = singleObj1.getInstance(); singleClass1.show(); var singleObj2 = new Single('2012-11-20'); var singleClass2 = singleObj2.getInstance(); singleClass2.show(); ``` 在上述代码中,通过调用Single.getInstance()方法两次获取到的单例实例是相同的,因此输出结果为: ``` This is a single instance created on 2012-11-10 This is a single instance created on 2012-11-10 ``` 这就是NodeJS中单例模式的基本概念和实现方法。使用单例模式可以确保在应用程序中只有一个实例被创建和访问,从而方便地共享资源或配置。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [NodeJS设计模式总结【单例模式,适配器模式,装饰模式,观察者模式】](https://download.csdn.net/download/weixin_38502693/12964096)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [设计模式之单例模式](https://blog.csdn.net/qq_45562973/article/details/123081148)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [Node.js单例模式](https://blog.csdn.net/LaFengDe9/article/details/71044908)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值