设计模式----适配器模式

结构型模式

AdapterPattern也成为包装或包装样式,当遇到以前写的模块接口跟当前设计的模块接口不吻合以致无法复用的时候,改如何在不该写原代码的情况下适应新的项目呢?适配器模式就是:将一个类的接口转换成客户希望的另外一个接口,使得原本不兼容的类可以一起工作。判断是否适用这个模式的简单方法就是两个具有不同接口的类所做的事情是否相同或相似。特别适用于项目后期的维护,维护人员不是当初的开发人员,就会产生功能相似但是接口不同的类。也适用于当新的项目需要适用第三方组件但其接口和新系统不同的时候,就可以适用改模式来匹配了。

      类A和类B都具有上传功能,类A是新项目中的类,实现上传只要一个upload函数,但是类B是实现上传就需要upload和校验成功否的check函数。这时类B所面临的修改就不是简简单单的修改方法名了,适用适配器模式,只要在适配器类里面重写类A的upload方法,在里卖弄集成类B的upload方法和check方法就可以了。满足开放和封闭原则。

举个例子:出门旅行我们都会带笔记本,但是各个国家的电压是不一定的,110V和220V都有,我们不可能将适用各种电压的充电器带上,只要带上电源适配器就好了,不管是多大的电压,经过适配器都可以转换成适合笔记本适用的。即笔记本类就是需要适配的类,电源接口就是面向用户的接口。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
public  interface  Adapter {
     void  powerSupply();
}
public  class  Adapter110V  extends  PowerPort110V  implements  Adapter {
     NoteBook noteBook =  new  NoteBook();
     @Override
     public  void  powerSupply() {
         // TODO Auto-generated method stub
         super .powerSupply();
         System.out.println( "将电压转换成笔记本需要的 了" );
         noteBook.work();
     }
}
public  class  Adapter220V  extends  PowerPort220V  implements  Adapter {
     NoteBook noteBook =  new  NoteBook();
     @Override
     public  void  powerSupply() {
         // TODO Auto-generated method stub
         super .powerSupply();
         System.out.println( "将电压转换成笔记本需要的 了" );
         noteBook.work();
     }
}
public  class  NoteBook {
     public  void  work(){
         System.out.println( "notebook is working" );
     }
}
//110v电源接口类
public  class  PowerPort110V {
     //适配器提供电源
     public  void  powerSupply(){
         System.out.println( "110v电源接口向外输出了110v电压" );
     }
}
//220v电源接口类
public  class  PowerPort220V {
     //适配器提供电源
     public  void  powerSupply(){
         System.out.println( "110v电源接口向外输出了220v电压" );
     }
}
public  static  void  main(String[] args) {
     // 出国前
     Adapter adapter =  new  Adapter220V();
     adapter.powerSupply();
     // 出国后
     adapter =  new  Adapter110V();
     adapter.powerSupply();
}

总结:适用时还需考虑:每个Adapter对Adaptee的皆苦和target的接口进行匹配是其工作量肯不一样所以adapter的工作范围是从简单地方法名的装换到支持完全不同的操作集合,也就是说adapter的工作量阙娟与adaptee与target二者接口的匹配程度;当第三方类适用一个特定的类时,如果所需假定条件越少,这个特定的类的可复用性就越高。

适配器可分为类适配器和对象适配器,区别如下:

1)对象适配器:不是通过继承的方式,而是通过对象组合的方式来进行处理。

2)类适配器:通过继承的方式来实现,将旧有的方法封装。

结构图:

麦库截图20141429144823298.jpg 

基本代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
//希望被适配而达到复用目的的类
public  class  Adaptee {
     public  void  specificRequest(){
         System.out.println( "客户发起特殊请求" );
     }
}
public  class  Target {
     //客户的基本请求
     public  void  request(){
         System.out.println( "客户发起普通的请求" );
     }
}
public  class  Adapter  extends  Target{
     private  Adaptee adaptee =  new  Adaptee();
     @Override
     public  void  request() {
         // TODO Auto-generated method stub
         adaptee.specificRequest();
     }
}
public  static  void  main( String  args[]) {
         //客户基本要求
         Target target =  new  Target();
         target.request();
         //客户特殊要求
         target =  new  Adapter();
         target.request();
     }

 

转载于:https://www.cnblogs.com/silence-hust/p/4133797.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值