适配器模式将某个类的接口转换成客户端期望的另一个接口表示,目的是消除由于接口不匹配所造成的类的兼容性问题。主要分为三类:类的适配器模式、对象的适配器模式、接口的适配器模式。
代码如下:
package com.ceshi5; public interface Targetable { /* 与原类中的方法相同 */ public void method1(); /* 新类的方法 */ public void method2(); }
package com.ceshi5; public class Source { public void method1() { System.out.println("这是原方法!"); } }
package com.ceshi5; public class Adapter extends Source implements Targetable { @Override public void method2() { System.out.println("这是目标方法!"); } }
package com.ceshi5; public class AdapterTest { public static void main(String[] args) { Targetable target = new Adapter(); target.method1(); target.method2(); } }
运行结果:
可以看出上面Adapter类实现接口只实现其中一个方法,另一个方法由父类实现。那么父类和接口算是适配上了。
这是类的适配器模式。
接下来是对象的适配器模式:
package com.ceshi5; public class Wrapper implements Targetable{ private Source source; public Wrapper(Source source){ super(); this.source = source; } @Override public void method2() { System.out.println("这是目标方法!"); } @Override public void method1() { source.method1(); } }
package com.ceshi5; public class AdapterTest { public static void main(String[] args) { Source source = new Source(); Targetable target = new Wrapper(source); target.method1(); target.method2(); } }
结果与上一个结果相同;只是将method1方法的输出通过引入source对象来调用。
接下来是接口适配器
package com.ceshi5; public abstract class Wrapper2 implements Sourceable{ public void method1(){} public void method2(){} }
package com.ceshi5; public class SourceSub1 extends Wrapper2{ public void method1(){ System.out.println("the sourceable interface‘s first Sub1!"); } }
package com.ceshi5; public class SourceSub2 extends Wrapper2{ public void method2(){ System.out.println("the sourceable interface‘s second Sub2!"); } }
package com.ceshi5; public class WrapperTest { public static void main(String[] args) { Sourceable source1 = new SourceSub1(); Sourceable source2 = new SourceSub2(); source1.method1(); source1.method2(); source2.method1(); source2.method2(); } }
原文:https://www.cnblogs.com/zhengyuanyuan/p/10748768.html