设计模式—适配器模式

来源:互联网 发布:淘宝买东西怎么评价 编辑:程序博客网 时间:2024/05/16 11:56
转载请注明出处:http://blog.csdn.net/singwhatiwanna/article/details/17659905

前言

适配器模式在设计模式体系中属于结构型模式,可以分为三类:类的适配器模式、对象的适配器模式和接口的适配器模式,由于类和接口的适配器模式需要适配器继承原有的类,而纯面向对象语言Java、C#都是不支持多继承的,这在一定程度上制约了类和接口的适配器模式的使用场景,故使用的时候要注意。

使用目的:将一个类的接口转换成客户希望的另外一个接口。适配器模式使得原本由于接口不兼容而不能一起工作的那些类可以一起工作。

类适配器模式

说明:

当新接口出现的时候,由于和老的接口不兼容,这个时候,我们采用一个适配器类实现新的接口并且继承老的业务类,这样就能同时处理新老业务。

示例代码:

[java] view plain copy
print?
  1. /** 
  2.  * 原始类 
  3.  */  
  4. class Source {  
  5.     public void oldFunction() {  
  6.         System.out.println(”oldFunction:Source”);  
  7.     }  
  8. }  
  9.   
  10. interface Target {  
  11.     void oldFunction();  
  12.   
  13.     // 新接口  
  14.     void newFunction();  
  15. }  
  16.   
  17. // 适配器,用来做接口转换  
  18. class Adapter extends Source implements Target {  
  19.   
  20.     public Adapter() {  
  21.         super();  
  22.     }  
  23.   
  24.     @Override  
  25.     public void newFunction() {  
  26.         System.out.println(”newFunction:Adapter”);  
  27.     }  
  28. }  
  29.   
  30. public class A {  
  31.     public static void main(String args[]) {  
  32.         Target target = new Adapter();  
  33.         target.oldFunction();  
  34.         target.newFunction();  
  35.     }  
  36. }  

输出:

oldFunction:Source
newFunction:Adapter

 

对象适配器模式

说明:当新接口出现的时候,由于和老的接口不兼容,这个时候,我们采用一个适配器类实现新的接口并在内部持有一个老业务逻辑的对象,这样就能把对老接口的调用全部中转给老的业务逻辑,从而解决接口的兼容性问题

示例代码:

[java] view plain copy
print?
  1. /** 
  2.  * 原始类 
  3.  */  
  4. class Source {  
  5.     public void oldFunction() {  
  6.         System.out.println(”oldFunction:Source”);  
  7.     }  
  8. }  
  9.   
  10. interface Target {  
  11.     void oldFunction();  
  12.   
  13.     // 新接口  
  14.     void newFunction();  
  15. }  
  16.   
  17. // 适配器,用来做接口转换  
  18. class Adapter implements Target {  
  19.   
  20.     // 适配器内部持有的原始类对象  
  21.     private Source mSource;  
  22.   
  23.     public Adapter(Source source) {  
  24.         mSource = source;  
  25.     }  
  26.   
  27.     @Override  
  28.     public void oldFunction() {  
  29.         // 这里调用原始类中的方法  
  30.         mSource.oldFunction();  
  31.     }  
  32.   
  33.     @Override  
  34.     public void newFunction() {  
  35.         System.out.println(”newFunction:Adapter”);  
  36.     }  
  37.   
  38. }  
  39.   
  40. public class A {  
  41.     public static void main(String args[]) {  
  42.         Source source = new Source();  
  43.         Target target = new Adapter(source);  
  44.         target.oldFunction();  
  45.         target.newFunction();  
  46.     }  
  47. }  

输出:

oldFunction:Source
newFunction:Adapter

 

接口适配器模式

说明:也叫缺省适配器模式,主要解决接口的复用问题:有时候可能我们的业务只需要使用接口中的某一个方法而不是全部方法,但是由于接口的语言特性而不得不实现全部的抽象方法,这样就会使得接口的使用过程很麻烦,特别是接口中存在很多抽象方法的时候。面对接口的这类问题,我们可以采用一个抽象类(也可以不是抽象类)去实现接口,然后让我们的类去继承这个抽象类同时只重写我们感兴趣的方法即可。

示例代码:

[java] view plain copy
print?
  1. interface Target {  
  2.     void function1();  
  3.   
  4.     void function2();  
  5.   
  6.     void function3();  
  7.   
  8.     void function4();  
  9. }  
  10.   
  11. //TargetWrapper实现了Target接口,并给出了默认实现  
  12. abstract class TargetWrapper implements Target {  
  13.     @Override  
  14.     public void function1() {  
  15.         System.out.println(”function1:TargetWrapper”);  
  16.     }  
  17.   
  18.     @Override  
  19.     public void function2() {  
  20.     }  
  21.   
  22.     @Override  
  23.     public void function3() {  
  24.     }  
  25.   
  26.     @Override  
  27.     public void function4() {  
  28.     }  
  29. }  
  30.   
  31. // 适配器,继承TargetWrapper,重写自己感兴趣的方法  
  32. class Adapter extends TargetWrapper {  
  33.   
  34.     public Adapter() {  
  35.         super();  
  36.     }  
  37.   
  38.     @Override  
  39.     public void function2() {  
  40.         System.out.println(”function4:Adapter”);  
  41.     }  
  42. }  
  43.   
  44. public class A {  
  45.     public static void main(String args[]) {  
  46.         Target target = new Adapter();  
  47.         target.function1();  
  48.         target.function2();  
  49.     }  
  50. }  

输出:

function1:TargetWrapper
function4:Adapter

原创粉丝点击