“接口隔离” 模式
- 在组织构建过程中,某些接口之间的直接依赖常常会带来很多问题、甚至根本无法实现。采用添加一层间接(稳定)接口,来隔离本来相互紧密关联的接口是一种常见的解决方案。
- 典型模式
- Facade
- Proxy
- Adapter
- Mediator
一、代码示例
**背景:**我们在做一个需求时,已经有现存的代码可以完成核心功能,但是现存的代码与我们所需要的存在一部分差异,这时候如果在原有代码的基础上重构,带来的成本太大,所以我们可以在原有代码的上层对其进行封装,使得该代码可以满足我们的需求。
interface ITarget {
void process();
}
interface IAdaptee{
void foo(int data);
int bar();
}
class OldClass implements IAdaptee {
//....
}
class Adapter implements ITarget {
protected IAdaptee adaptee;
public Adapter(IAdaptee adaptee) {
this.adaptee = adaptee;
}
@Override
public void process() {
int data = adaptee.bar();
adaptee.foo(data);
}
}
class Client {
public static void main(String[] args) {
IAdaptee adaptee = new OldClass();
ITarget target = new Adapter(adaptee);
target.process();
}
}
二、动机
在软件系统中,由于应用环境的变化,常常需要将“一些现存的对象”放到新的环境中应用,但是新环境要求的接口是这些现存对象所不满足的。
如何应对这种“迁移的变化”?如何技能利用现有对象的良好实现?同时又能满足新的应用环境所要求的接口?
三、模式定义
将一个类的接口转换成客户希望的另一个接口。Adapter模式使得原本由于接口不兼容而不能在一起工作的那些类可以一起工作。
什么时候使用:
- 你想使用一个已经存在的类,而它的接口不符合你的要求;
- 你想创建一个可以复用的类,该类可以与其他不相关的类或不可预见的类协同工作