设计模式——适配器

ADAPTER(适配器)

 

1、 意图

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

2、 别名

包装器Wrapper

3、 适用性

  • 你想使用一个已经存在的类,而它的接口不符合你的需求。
  • 你想创建一个可以复用的类,该类可以与其他不相关的类或不可预见的类(即那些接口可能不一定兼容的类)协调工作。
  • (仅适用于对象Adapter)你想使用一些已经存在的子类,但是不可能对每一个都进行子类化以匹配它们的接口。对象适配器可以适配它的父类接口。

4、 结构

类适配器使用多重继承对一个接口与另一个接口进行匹配。由于Java不支持多重继承,所以目前没有涉及。如下图所示:


对象匹配器依赖于对象组合,如下图所示:


5、 参与者

Target——定义Client使用的与特定领域相关的接口。

Client——与符合Target接口的对象协调。

Adaptee——定义一个已经存在的接口,这个接口需要适配器。

Adapter——对Adaptee的接口与Target接口进行适配。

6、 协作

Client在Adapter实例上调用一些操作。接着适配器调用Adapter的操作实现这个请求。

7、 效果

类适配器和对象适配器有不同的权衡。

类适配器:

  •  用一个具体的Adapter类对Adaptee和Target进行匹配。结果是当我们想要匹配一个类及所有它的子类时,类Adapter将不能胜任工作。
  • 使得Adapter可以重定义Adaptee的部分行为,因为Adapter是Adaptee的一个子类。
  • 仅仅引入一个对象,并不需要额外的指针以间接得到adaptee。

对象适配器:

  • 允许一个Adapter与多个Adaptee——即Adapter本身以及它的所有子类(如果有子类的话)——同时工作。Adapter也可以一次给所有的Adaptee添加功能。
  • 使得重定义Adaptee的行为比较困难。这就需要生成Adapter的子类并且使得Adapter引用这个子类而不是引用Adaptee本身。

使用Adapter模式时需要考虑的其他一些因素有:

1)  Adapter的匹配程度。对Adapter的接口与Target的接口进行匹配的工作量各个Adapter可能不一样。工作范围可能是,从简单的接口转换到支持完全不同的操作集合。Adapter的工作量取决于Target接口与Adapter接口的相似程度。

2)  可插入的Adapter。当其他的类使用一个类时,如果所需要的假定条件越少,这个类就更具复用性。如果将接口匹配构建为一个类,就不需要假定对其他的类可见的是一个相同的接口。也就是说,接口匹配使得我们可以将自己的类加入到一些现有的系统中去,而这些系统对这个类的接口可能会有所不同。

3)  使用双向适配器提供透明操作。使用适配器的一个潜在问题是,它们不对所有的客户都透明。被适配的对象不再兼容Adapter的接口,因此并不是所有Adapter对象可以被使用的地方都可以被使用。双向适配器提供了这样的透明性。在两个不同的客户需要用不同的方式查看同一个对象时,双向适配器尤其有用。

8、 代码示例

Target

package com.examples.pattern.adapter;

/**
 * 定义客户端使用的接口,与特定领域相关
 */
public interface Target {

	public void request();

}
Adaptee

package com.examples.pattern.adapter;

/**   
* 已经存在的接口或类       
*/
public class Adaptee {
	
	public void specifiRequest(){
		System.out.println("adaptee's specifiRequest");
	}

}
Adapter

package com.examples.pattern.adapter;

/**
 * 适配器
 */
public class Adapter implements Target {

	/**
	 * 持有需要被适配的接口对象
	 */
	private Adaptee adaptee;

	/**
	 * 构造方法,传入需要被适配的对象
	 * 
	 * @param adaptee
	 *            需要被适配的对象
	 */
	public Adapter(Adaptee adaptee) {
		this.adaptee = adaptee;
	}

	@Override
	public void request() {
		adaptee.specifiRequest();
		System.out.println("this is the Adapter's request");
	}

}
Client

package com.examples.pattern.adapter;

public class Client {
	
	public static void main(String[] args) {
		//创建需要适配的对象
		Adaptee adaptee = new Adaptee();
		//创建客户端需要调用的接口对象
		Target target = new Adapter(adaptee);
		//请求处理
		target.request();
	}

}

9、 相关模式

Bridge模式的结构与对象适配器相似,但是Bridge模式的出发点不同:Bridge目的是将接口部分和实现部分分离,从而对它们可以较为容易也相对独立地加以改变。而Adapter则意味着改变一个已有对象的接口。

Decorator模式增强了其他对象的功能而同时又不改变它的接口。因此decorator对应用程序的透明性比适配器要好。结果是decorator支持递归组合,而纯粹使用适配器是不可能实现这一点的。

Proxy模式在不改变它的接口的条件下,为另一个对象定义了一个代理。


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值