更新时间:2022-09-13 20:29:46
把一个接口或类变成另外一种。
java.util.Arrays#asList()
javax.swing.JTable(TableModel)
java.io.InputStreamReader(InputStream)
java.io.OutputStreamWriter(OutputStream)
javax.xml.bind.annotation.adapters.XmlAdapter#marshal()
javax.xml.bind.annotation.adapters.XmlAdapter#unmarshal()
目标角色(Target): 定义Client使用的与特定领域相关的接口,即期待得到的接口。
客户角色(Client):与符合Target接口的对象协同。
被适配橘色(Adaptee):定义一个已经存在并已经使用的接口,这个接口需要被适配。
适配器角色(Adapte):适配器模式的核心。
它将对被适配Adaptee角色已有的接口转换为目标角色Target匹配的接口,对Adaptee的接口与Target接口进行适配.
1
2
3
4
5
6
7
8
|
/** * 所期待得到的接口
*/
public interface Target {
/**类似中国的电源接口*/
public void expectMethod();
} |
1
2
3
4
5
6
7
8
9
10
|
/** * 需要被适配的接口,类似国外的电源接口
*/
public class Adaptee {
/**德国电源插口*/
public void notMatchMethod(){
System.out.println( "这是待适配的德国电源插口__" );
}
} |
1.类适配器模式
1
2
3
4
5
6
7
8
9
10
11
12
13
|
/** * 类适配器模式
* 适配器角色Adapter扩展了Adaptee,同时又实现了目标(Target)接口。
*/
public class Adapter1 extends Adaptee implements Target{
@Override
public void expectMethod() {
//可以调用Adaptee的方法做适当修改
notMatchMethod();
System.out.println( "在适配器中实现期待的方法" );
}
} |
Adapter与Adaptee是继承关系
用一个具体的Adapter类和Target进行匹配。结果是当我们想要一个匹配一个类以及所有它的子类时,类Adapter将不能胜任工作
使得Adapter可以重定义Adaptee的部分行为,因为Adapter是Adaptee的一个子集
仅仅引入一个对象,并不需要额外的指针以间接取得adaptee
2.对象适配器模式
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
/** * 对象适配器模式
* 通过对象的委托实现
*/
public class Adapter2 {
private Adaptee adaptee;
public Adapter2(Adaptee adaptee){
this .adaptee=adaptee;
}
public void notMatchMethod(){
//
this .adaptee.notMatchMethod();
}
public void expectMethod(){
//需要的接口
System.out.println( "在适配器中实现期待的方法" );
}
} |
Adapter与Adaptee是委托关系
允许一个Adapter与多个Adaptee同时工作。Adapter也可以一次给所有的Adaptee添加功能
使用重定义Adaptee的行为比较困难
无论哪种适配器,宗旨都是:保留现有类所提供的服务,向客户提供接口,以满足客户的期望。
即在不改变原有系统的基础上,提供新的接口服务。
使用一个已经存在的类,而它的接口不符合你的需求,
创建一个可以复用的类,该类可以与其他不相关的类或不可预见的类(即那些接口可能不一定兼容的类)协同工作。
本文转自邴越博客园博客,原文链接:http://www.cnblogs.com/binyue/p/4304679.html,如需转载请自行联系原作者