优点1、客户端通过适配器可以透明地调用目标接口。
2、复用了现存的类,程序员不需要修改原有代码而重用现有的适配者类。
3、将目标类和适配者类解耦,解决了目标类和适配者类接口不一致的问题。
4、在很多业务场景中符合开闭原则。
缺点1、适配器编写过程需要结合业务场景全面考虑,可能会增加系统的复杂性。
2、增加代码阅读难度,降低代码可读性,过多使用适配器会使系统代码变得凌乱。
知识点类适配器模式: 可采用多重继承方式实现,如 c++ 可定义一个适配器类来同时继承当前系统的业务接口和现有组件库中已经存在的组件接口;java 不支持多继承,但可以定义一个适配器类来实现当前系统的业务接口,同时又继承现有组件库中已经存在的组件。
对象适配器模式: 可釆用将现有组件库中已经实现的组件引入适配器类中,该类同时实现当前系统的业务接口。现在来介绍它们的基本结构。
适配器模式实现案例: 虹猫利用火晶石催发火舞旋风剑气
目标(target)接口:长虹剑气
适配者(adaptee)类:火舞旋风剑气
适配器(adapter)类:火晶石
虹猫目前只能催发长虹剑气,但是他想催发火舞旋风剑气
只能借助火晶石的力量来将长虹剑气转化为火舞旋风剑气
注意: 我这里是让火舞旋风剑气适配长虹剑气
类适配器长虹剑气声明一个长虹剑气的接口,包含一个催动长虹剑气的抽象方法
public interface chang { void chang();}
火舞旋风剑气火舞旋风剑气类,声明一个催发火舞旋风剑气的方法。
public class huo { public void huo() { system.out.println("火舞旋风剑气"); }}
火晶石火晶石类,继承火舞旋风剑气类(目的:继承了就可以使用类里面的方法),实现了长虹剑气接口(目的:实现催发长虹剑气的方法)。在催发长虹剑气的方法中调用了催发火舞旋风剑气的方法。
public class jingshi extends huo implements chang { @override public void chang() { huo(); }}
测试public class demo { public static void main(string[] args) { chang haha = new jingshi(); haha.chang(); }}
对象适配器长虹剑气声明一个长虹剑气的接口,包含一个催动长虹剑气的抽象方法
public interface chang { void chang();}
火舞旋风剑气火舞旋风剑气类,声明一个催发火舞旋风剑气的方法。
public class huo { public void huo() { system.out.println("火舞旋风剑气"); }}
火晶石火晶石类,实现了长虹剑气接口,声明了一个火舞旋风剑气属性,并实现了催发长虹剑气的方法。将催动火舞旋风剑气的方法放在了催动长虹剑气的方法中。
public class jingshi implements chang { private huo huo; jingshi() { } jingshi(huo huo) { this.huo = huo; } @override public void chang() { huo.huo(); }}
测试new一个火舞旋风剑气对象,new一个火晶石对象,并将火舞旋风剑气对象传入火晶石对象中。
public class demo { public static void main(string[] args) { huo huo = new huo(); chang haha = new jingshi(huo); haha.chang(); }}
以上就是java设计模式的适配器模式怎么实现的详细内容。
