Adapter模式也被成为Wrapper模式。适配器模式用于填补“现有的程序”和“所需的程序”之间差异的设计模式。

  Adapter模式有两种,即使用继承的适配器和使用委托的适配器。

  1.使用继承的适配器

  

  下面根据代码来解释使用继承的适配器这种模式。

  1. package BigJunOba.bjtu.Adapter;
  2.  
  3. public class Banner {
  4.  
  5. private String string;
  6.  
  7. public Banner(String string) {
  8. this.string = string;
  9. }
  10.  
  11. public void showWithParen() {
  12. System.out.println("(" + string + ")");
  13. }
  14.  
  15. public void showWithAster() {
  16. System.out.println("*" + string + "*");
  17. }
  18. }

  这里的Banner类就是现有的程序。有可以对字符串进行操作的showWithParen和showWithAster方法。

  1. package BigJunOba.bjtu.Adapter;
  2.  
  3. public interface Print {
  4.  
  5. public abstract void printWeak();
  6. public abstract void printStrong();
  7. }

  Print接口声明了两种方法,即加括号printWeak和加星号printStrong方法。这里的Print接口就是实际的需求,现在要做的就是需要一个适配器。

  1. package BigJunOba.bjtu.Adapter;
  2.  
  3. public class PrintBanner extends Banner implements Print {
  4.  
  5. public PrintBanner(String string) {
  6. super(string);
  7. }
  8.  
  9. @Override
  10. public void printWeak() {
  11. showWithParen();
  12. }
  13.  
  14. @Override
  15. public void printStrong() {
  16. showWithAster();
  17. }
  18. }

  PrintBanner类就是这个适配器。该类继承了Banner类并且实现了需求。

  PrintBanner类使用showWithParen方法实现了printWeak,使用showWithAster方法实现了printStrong。

  1. package BigJunOba.bjtu.Adapter;
  2.  
  3. public class Main {
  4.  
  5. public static void main(String[] args) {
  6. Print print = new PrintBanner("hhhhh");
  7. print.printWeak();
  8. print.printStrong();
  9. }
  10. }
  1. (hhhhh)
  2. *hhhhh*

  通过测试结果我们可以看出使用继承的适配器的作用。

  2.使用委托的适配器

  下面根据代码来解释使用委托的适配器这种模式。

  主要的Main类和Banner类不变。

  1. package BigJunOba.bjtu.Adapter;
  2.  
  3. public abstract class Print {
  4.  
  5. public abstract void printWeak();
  6. public abstract void printStrong();
  7. }

  将Print接口改成一个抽象类。

  1. package BigJunOba.bjtu.Adapter;
  2.  
  3. public class PrintBanner extends Print {
  4.  
  5. private Banner banner;
  6.  
  7. public PrintBanner(String string) {
  8. this.banner = new Banner(string);
  9. }
  10.  
  11. @Override
  12. public void printWeak() {
  13. banner.showWithParen();
  14. }
  15.  
  16. @Override
  17. public void printStrong() {
  18. banner.showWithAster();
  19. }
  20.  
  21. }

  然后PrintBanner类继承Print抽象类。

  由于在PrintBanner类的banner字段中保存了Banner类的实例,该实例是在PrintBanner类的构造函数中生成的。然后printWeak和printStrong方法会通过banner字段调用banner类的showWithParen和showWithAster方法。这种在执行PrintBanner类的方法时,将处理交给其他实例即Banner实例处理的方式叫委托。

  两种适配器模式的类图。

  

设计模式(二)Adapter模式的更多相关文章

  1. 设计模式--适配器(Adapter)模式

    今天学习另一个设计模式,适配器(Adapter)模式,这是一个共同方向,但有特殊要求,就应用到此设计模式.写到这里,想起很久以前,有写过一篇<ASP.NET的适配器设计模式(Adapter)&g ...

  2. 设计模式之Adapter模式

    说起Adapter,STL里的stack和queue都是adapter,底层是deque,隐藏了deque的一些接口,使得其可以达到FIFO是queue,LIFO是stack. The STL sta ...

  3. 设计模式:Adapter模式

    目的:复用代码和兼容以前的代码 思想:提供一个中间层,做兼容 方法:“继承”的方式,“委托”的方式 继承关系图: 委托方式 继承方式 例子: //原来的打印 class Print { public: ...

  4. 2、适配器 adapter 模式 加个"适配器" 以便于复用 结构型设计模式

    1.什么是适配器模式? 适配器如同一个常见的变压器,也如同电脑的变压器和插线板之间的电源连接线,他们虽然都是3相的,但是电脑后面的插孔却不能直接插到插线板上. 如果想让额定工作电压是直流12伏特的笔记 ...

  5. 设计模式之(二)Adapter模式

    今天学习Adapter模式,An adapter helps two incompatible interfaces to work together. This is the real world ...

  6. 8.3 GOF设计模式二: 适配器模式 Adapter

    GOF设计模式二: 适配器模式 Adapter  为中国市场生产的电器,到了美国,需要有一个转接器才能使用墙上的插座,这个转接 器的功能.原理?复习单实例模式  SingleTon的三个关键点  ...

  7. 设计模式---接口隔离模式之适配器模式(Adapter)

    一:概念 通过Adapter模式可以改变已有类(或外部类)的接口形式 二:动机 在软件系统中,由于应用环境的变化,常常需要将“一些现存的对象”放在新的环境中应用,但是新环境要求的接口是这些现存对象所不 ...

  8. java设计模式—Adapter模式

    1.核心意图:     将一个类的接口转换成客户希望的另外一个接口,从而使得原本由于接口不兼容而不能一起工作的类可以一起工作. 该模式的目标是通过一个代理(这里是Adapter),在原来的类(Adap ...

  9. 设计模式 ( 二十 ) 访问者模式Visitor(对象行为型)

    设计模式 ( 二十 ) 访问者模式Visitor(对象行为型) 1.概述 在软件开发过程中,对于系统中的某些对象,它们存储在同一个集合collection中,且具有不同的类型,而且对于该集合中的对象, ...

随机推荐

  1. 关于json字符串与实体之间的严格验证

    在一个项目中要求严格验证传入的json字符串与定义的 类匹配,否则不记录.感觉这个严格验证找了好多资料才找到,可能用的人比较少,特摘出来给大家分析,直接上代码了:   using Newtonsoft ...

  2. Asteroids POJ - 3041 二分图最小点覆盖

       Asteroids POJ - 3041 Bessie wants to navigate her spaceship through a dangerous asteroid field in ...

  3. .net core 3.0 Signalr - 08 业务实现-客户端demo

    由于signalr作为一个单独的推送系统,跟业务系统是分离开的,所以此处模拟一个业务系统,新建一个.net core app项目 ## 模拟实现一个登录功能 我们的登录很简单,当进入系统,如果检测到用 ...

  4. ELK 学习笔记之 Logstash之inputs配置

    Logstash之inputs配置: input plugin doc: https://www.elastic.co/guide/en/logstash/current/index.html 插件很 ...

  5. Linux被中断的系统调用

    慢系统调用,指的是可能永远无法返回,从而使进程永远阻塞的系统调用,比如无客户连接时的accept.无输入时的read都属于慢速系统调用. 在Linux中,当阻塞于某个慢系统调用的进程捕获一个信号,则该 ...

  6. Nullable Reference Types 可空引用类型

    在写C#代码的时候,你可能经常会遇到这个错误: 但如果想避免NullReferenceException的发生,确实需要做很多麻烦的工作. 可空引用类型 Null Reference Type 所以, ...

  7. k8s pod访问不通外网问题排查

    环境概况 自建k8s集群,主机操作系统ubuntu16.04,k8s版本v1.14, 集群网络方案calico-3.3.6. worker节点数50+,均为GPU物理服务器,服务器类型异构,如Nvid ...

  8. [Swoole] 在Ubuntu下安装、快速开始

    本文主要讲述在 Ubuntu 下编译安装 Swoole,并根据官方文档给出的demo进行了测试和搬运,包括:TCP服务器.UDP服务器.HTTP服务器.WebSocket服务器.异步客户端.定时器和协 ...

  9. Spring Boot WebFlux 快速入门实践

    02:WebFlux 快速入门实践 Spring Boot 2.0 spring.io 官网有句醒目的话是: BUILD ANYTHING WITH SPRING BOOT Spring Boot ( ...

  10. 使用lombok中的log

    idea中安装lombok插件 引入lombok依赖 <!-- https://mvnrepository.com/artifact/org.projectlombok/lombok --> ...