适配器模式【结构型模式C++】

news/2025/2/11 18:19:09/

1.概述

    适配器模式是一种结构型设计模式, 又称为变压器模式、包装模式(Wrapper) 将一个类的接口变换成客户端所期待的另一种接口,从而使原本因接口不匹配而无法在一起工作的两个类能够在一起工作。

2.结构

  • Target:适配器的内容,例如客户端使用的目标接口;
  • Adaptee:被适配的内容,例如不兼容的接口;
  • Adapter:适配器,把 Adaptee 适配成 Target

3.实现 

3.1 实例类比

       在生活中存在各类适配器,交流电220V会转化为各类所需电压, 以手机适配器为例。在给手机充电 手机充电器相当于 Adapter适配器 ,220V的交流电 相当于 Adaptee 被适配者5V的直流电 相当于 Target目标 

3.2 具体实现
#include <iostream>
#include <string>
using namespace std;//被适配类即待转化的类
class Adaptee {
public:int OutPut220V() {std::cout << "正常220V电压..." << endl;return 220;}
};//转化目标
class Target {
public:virtual int OutPut5V()=0;
};//适配器
class Adapter :public Target {
public:int OutPut5V() {//输入的待转化电压int a = inPut_->OutPut220V();//转化方法int b = a / 44;//返回转化结果std::cout << "220V电压转化为5V电压..." << endl;return b;}void SetInpt(Adaptee * inPut) {inPut_ = inPut;}private:Adaptee * inPut_;
};int main()
{Adaptee * input_ = new Adaptee();Adapter * adater_ = new Adapter();adater_->SetInpt(input_);adater_->OutPut5V();return 0;
}
3.3运行结果

4.状态设计模式优缺点   

   优点: 
  • 将目标类和适配者类解耦
  • 增加了类的透明性和复用性,将具体的实现封装在适配者类中,对于客户端类来说是透明的,而且提高了适配者的复用性
  • 灵活性和扩展性都非常好,符合开闭原则。如果不想用就可以卸载适配器
   缺点:
  • 过多地使用适配器,会让系统非常零乱,不易整体进行把握。
  • 由于 JAVA 至多继承一个类,所以至多只能适配一个适配者类,而且目标类必须是抽象类。

5 应用场景

  • 两个类所做的事情相同或相似,但是具有不同的接口时要使用
  • 在双方都不太容易修改的时候再使用适配器模式适配,而不是一有不同时就使用它。
  • 系统需要使用一些现有的类,而这些类的接口与系统要求的接口不兼容。
  • 需要创建一个可复用的类,该类与一些不兼容的类合作工作,而不是修改这些类的代码。
  • 在已有的系统中,希望增加一些额外的功能,而这些功能需要与已有的类协同工作,但是不能对这些类进行修改。

http://www.ppmy.cn/news/1427558.html

相关文章

常用的数据结构及算法

一、数据结构 &#xff08;一&#xff09;线性结构&#xff1a;一对一。 1.可以使用数组、链表来表示。数组又分为静态数组和动态数组两种。链表常用的是单链表。 2.两种特殊的线性结构&#xff1a;队列和栈。其中队列是先进先出&#xff08;排队&#xff09;&#xff0c;栈…

linux限权

shell命令以及运行原理 什么是shell命令&#xff1a; 将使用者的命令翻译给核心&#xff08;kernel&#xff09;处理。同时&#xff0c;将核心的处理结果翻译给使用者。 shell就相当于操作系统外的一层外壳 其实就是登录linux时的一个可执行程序&#xff08;进程&#xff09…

了解以太网环网保护倒换(ERPS)

以太网环网保护交换&#xff08;ERPS&#xff09;有助于实现高可靠性和网络稳定性。本文概述了ERPS&#xff0c;包括其定义、基本概念和优点。 什么是ERPS&#xff1f; 以太网环网保护切换&#xff08;ERPS&#xff09;是一种标准化的网络设计方法&#xff0c;旨在确保以太网…

使用 Spring AOP 和 Guava RateLimiter 实现 API 限流

在高并发的应用场景下,合理的限流策略是保证系统稳定性的重要手段之一。限流可以防止系统资源被耗尽,避免雪崩效应的发生。本文将介绍如何使用 Spring AOP 和 Guava RateLimiter 实现API限流,并支持自定义限流超时时间。 引入依赖 首先,需要在 pom.xml 中引入 Guava 依赖: &…

面试题集中营—分布式共识算法

分布式共识算法目标 分布式主要就是为了解决单点故障。一开始只有一个服务节点提供服务&#xff0c;如下图所示。那么如果服务节点挂了&#xff0c;对不起等着吧。 为了服务的高可用性&#xff0c;我们一般都会多引入几个副节点当备份&#xff0c;当服务节点挂了&#xff0c;就…

什么是三高架构

三高架构是指在软件系统设计与开发中&#xff0c;注重解决高并发性、高可用性和高性能的架构设计模式。 高并发性&#xff1a;指系统能够处理大量并发请求的能力。在高并发场景下&#xff0c;系统需要具备有效的并发处理机制&#xff0c;以保证系统能够快速、准确地响应大量并…

【设计模式】组合模式

目录 什么是组合模式 代码实现 什么是组合模式 Java中的组合模式&#xff08;Composite Pattern&#xff09;是一种结构型设计模式&#xff0c;它允许将对象组合成树形结构以表示部分-整体的层次结构。组合模式使得客户端对单个对象和组合对象的处理具有一致性&#xff0c;因…

python-selenium +Chrome driver环境配置

selenium Chrome driver环境配置_chromedriver 122.0.6261.112-CSDN博客