适配器模式
一、适配器模式的概念和角色
(一)、适配器的概念
适配器又叫做变压器模式,它的功能是将一个类的接口变成客户端所期望的另一种接口,从而使原本因接口不匹配而导致无法在一起工作的两个类能够一起工作,属于结构型设计模式。
也就是说,当前系统存在两种接口A和B,客户只支持访问A接口,但是当前系统没有A接口对象,但是有B接口对象,但客户无法识别B接口,因此需要通过一个适配器C,将B接口内容转换为A接口,从而使得客户能够从A接口获取得到B接口内容。
适配器其实就起着转化/委托的作用,将一种接口转化为另一种符合需求的接口。
(二)、适配器的角色
1、目标角色(Target):我们期待的接口
2、源角色(Adaptee):存在于系统中,内容满足客户需求(需转换),但接口不匹配的接口实例
3、适配器(Adapter):将源角色转化为目标角色的类实例
二、适配器的应用模式
1、已经存在的类,它的方法和需求不匹配(方法结果相同或相似)的情况
2、适配器模式不是软件设计阶段考虑的设计模式,是随着软件维护,由于不同产品,不同厂家造成功能类似而接口不相同情况下的解决方案。
三、类适配器的代码示例
Adaptee:AC220类
public class AC220 {
public int outputAC220V() {
int output = 220;
System.out.println("输出电压:" + output + "V");
return output;
}
}
Target:DC5接口
public interface DC5 {
int outputDC5V();
}
Adapter:PowerAdapter类
public class PowerAdapter extends AC220 implements DC5 {
@Override
public int outputDC5V() {
int adapterInput = super.outputAC220V();
int adapterOutput = adapterInput / 44;
System.out.println("输入AC" + adapterInput + "输出DC" + adapterOutput);
return adapterOutput;
}
}
测试类:
public class Test {
public static void main(String[] args) {
DC5 adapter = new PowerAdapter();
adapter.outputDC5V();
}
}
四、对象适配器的代码示例
Adaptee:AC220类
public class AC220 {
public int outputAC220V() {
int output = 220;
System.out.println("输出电压:" + output + "V");
return output;
}
}
Target:DC5接口
public interface DC5 {
int outputDC5V();
}
Adapter:PowerAdapter类
public class PowerAdapter implements DC5 {
private AC220 ac220;
public PowerAdapter(AC220 ac220) {
this.ac220 = ac220;
}
@Override
public int outputDC5V() {
int adapterInput = ac220.outputAC220V();
int adapterOutput = adapterInput / 44;
System.out.println("输入AC" + adapterInput + "输出DC" + adapterOutput);
return adapterOutput;
}
}
测试类:
public class Test {
public static void main(String[] args) {
DC5 adapter = new PowerAdapter(new AC220());
adapter.outputDC5V();
}
}
五、接口适配器的代码示例
Adaptee:AC220类
public class AC220 {
public int outputAC220V() {
int output = 220;
System.out.println("输出电压:" + output + "V");
return output;
}
}
Target:DC接口
public interface DC {
int output5V();
int output12V();
int output24V();
int output36V();
}
Adapter:PowerAdapter类
public class PowerAdapter implements DC {
private AC220 ac220;
public PowerAdapter(AC220 ac220) {
this.ac220 = ac220;
}
@Override
public int output5V() {
int adapterInput = ac220.outputAC220V();
int adapterOutput = adapterInput / 44;
System.out.println("输入AC" + adapterInput + "输出DC" + adapterOutput);
return adapterOutput;
}
@Override
public int output12V() {
return 0;
}
@Override
public int output24V() {
return 0;
}
@Override
public int output36V() {
return 0;
}
}
测试类:
public class Test {
public static void main(String[] args) {
DC adapter = new PowerAdapter(new AC220());
adapter.output5V();
}
}
六、适配器和装饰器模式的对比
装饰器模式 | 适配器模式 | |
---|---|---|
形式 | 是一种非常特别的适配器模式 | 没有层级关系,装饰器有层级关系 |
定义 | 装饰器和被装饰器都实现同一个接口,主要目的是为了扩展之后保留OOP关系 | 采用继承或代理的形式进行包装 |
关系 | 满足is-a的关系 | 满足has-a的关系 |
功能 | 注重覆盖、扩展 | 注重兼容、转换 |
设计 | 前置考虑 | 后置考虑 |
七、适配器模式的优缺点
(一)、优点
1、能提高类的透明性和复用,现有的类复用但不需要改变
2、目标类和适配器类解耦,提高程序的扩展性
3、在很多业务场景中符合开闭原则
(二)、缺点
1、适配器编写过程需要全面考虑,可能会增加系统的复杂性
2、增加代码阅读难度,降低代码可读性,过多使用适配器会使系统代码变得凌乱