时间:2022-08-28 09:28:59 | 栏目:JAVA代码 | 点击:次
模式: 适配器模式
案例: 虹猫利用火晶石催发火舞旋风剑气
适配器模式(Adapter)的定义如下: 将一个类的接口转换成客户希望的另外一个接口,使得原本由于接口不兼容而不能一起工作的那些类能一起工作。适配器模式分为类结构型模式和对象结构型模式两种,前者类之间的耦合度比后者高,且要求程序员了解现有组件库中的相关组件的内部结构,所以应用相对较少些。
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(); } }
类适配器的重点在于类,是通过构造一个继承Adaptee类来实现适配器的功能;
对象适配器的重点在于对象,是通过在直接包含Adaptee类来实现的,当需要调用特殊功能的时候直接使用Adapter中包含的那个Adaptee对象来调用特殊功能的方法即可