设计模式学习-适配器模式(结构型)
2016-08-11 20:55
267 查看
设计模式五:适配器模式
意图:将一个类的接口转换成客户希望的另外一个接口,使得以前由于接口不兼容不能一起工作的类可以一起工作适用性:
有一个现存的类,你想要使用,但是接口不符合你的需要。
你想创建一个可以复用的类,该类可以与其他不相关的类或不可预见的类(即那些接口可能不一定兼容的类)协同工作。
(仅适用于对象Adapter)你想使用一些已经存在的子类,但是不可能对每一个都进行子类化以匹配它们的接口。对象适配器可以适配它的父类接口。
结构:
参与者
•目标角色(Target):— 定义Client使用的与特定领域相关的接口。
• 客户角色(Client):与符合Target接口的对象协同。
• 被适配的角色(Adaptee):定义一个已经存在并已经使用的接口,这个接口需要适配。
• 适配器角色(Adapte) :适配器模式的核心。它将对被适配Adaptee角色已有的接口转换为目标角色Target匹配的接口。对Adaptee的接口与Target接口进行适配.
类适配器与对象适配器不同
类适配器:
• 用一个具体的Adapter类对Adaptee和Target进行匹配。结果是当我们想要匹配一个类以及所有它的子类时,类Adapter将不能胜任工作。
• 使得Adapter可以重定义Adaptee的部分行为,因为Adapter是Adaptee的一个子类。
• 仅仅引入了一个对象,并不需要额外的指针以间接得到 Adaptee。
对象适配器
• 允许一个Adapter与多个Adaptee—即Adaptee本身以及它的所有子类(如果有子类的话)—同时工作。Adapter也可以一次给所有的Adaptee添加功能。
• 使得重定义Adaptee的行为比较困难。这就需要生成Adaptee的子类并且使得Adapter引用这个子类而不是引用Adaptee本身。
使用Adapter模式时需要考虑的其他一些因素有:
1) Adapter的匹配程度 对Adaptee的接口与Target的接口进行匹配的工作量各个Adapter可能不一样。Adapter的工作量取决于Target接口与Adaptee接口的相似程度
2) 可插入的Adapter 当其他的类使用一个类时,如果所需的假定条件越少,这个类就更具可复用性。如果将接口匹配构建为一个类,就不需要假定对其他的类可见的是一个相同的接口。也就是说,接口匹配使得我们可以将自己的类加入到一些现有的系统中去,而这些系统对这个类的接口可能会有所不同。
3) 使用双向适配器提供透明操作 使用适配器的一个潜在问题是,它们不对所有的客户都透明。被适配的对象不再兼容 Adaptee的接口,因此并不是所有 Adaptee对象可以被使用的地方它都可以被使用。双向适配器提供了这样的透明性。在两个不同的客户需要用不同的方式查看同一个对象时,双向适配器尤其有用。
在实现适配器时,要注意,公共继承target类,私有继承安排adaptee类
例子:
//双端队列 class Deque { public: void push_back(int x) { cout<<"Deque push_back"<<endl; } void push_front(int x) { cout<<"Deque push_front"<<endl; } void pop_back() { cout<<"Deque pop_back"<<endl; } void pop_front() { cout<<"Deque pop_front"<<endl; } }; //顺序容器 class Sequence { public: virtual void push(int x) = 0; virtual void pop() = 0; }; //栈 class Stack: public Sequence { public: void push(int x) { deque.push_back(x); } void pop() { deque.pop_back(); } private: Deque deque; //双端队列 }; //队列 class Queue: public Sequence { public: void push(int x) { deque.push_back(x); } void pop() { deque.pop_front(); } private: Deque deque; //双端队列 };
int main() { Sequence *s1 = new Stack(); Sequence *s2 = new Queue(); s1->push(1); s1->pop(); s2->push(1); s2->pop(); delete s1; delete s2; return 0; }
实现部分的代码参考于
http://blog.csdn.net/wuzhekai1985/article/details/6665542
相关文章推荐
- 设计模式深入学习---Adapter 适配器模式(结构型模式)
- 设计模式学习之适配器模式(Adapter,结构型模式)(14)
- 跟着实例学习设计模式(8)-适配器模式adapter(结构型)
- 【设计模式学习笔记七】【结构型模式】【适配器模式(Adapter)】
- 设计模式学习(结构型模式)—适配器模式(Adapter)
- 设计模式学习日志(12)-Flyweight享元(结构型模式)
- 白话设计模式--结构型模式之 适配器模式(Adapter)
- 设计模式学习笔记(六):结构型模式
- 设计模式学习笔记(十五)——结构型模式总结
- 设计模式学习系列之UML图(结构型模式)
- 设计模式学习笔记之适配器模式
- 设计模式学习:适配器模式
- head first 设计模式学习随笔(7)----适配器模式和外观模式
- 白话设计模式 --结构型模式--装饰者(Decorator)模式,适配器模式和外观模式
- 设计模式学习笔记1 - Adapter(适配器模式)
- 设计模式学习(六)结构型模式初步了解
- 设计模式学习(十)结构型模型总结
- 设计模式学习-提供者和适配器模式
- 设计模式学习笔记十一:适配器模式(Adapter Pattern)
- 学习笔记:7种结构型设计模式简单对比