本文共 1918 字,大约阅读时间需要 6 分钟。
把一个接口或类变成另外一种。
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,如需转载请自行联系原作者