## 适配器模式
## 一、适配器模式
讲一个类的接口装换成客户希望的另外一个接口适配器模式使得原本由于接口不兼容而不能一起工作的哪些类可以一起工作。
用于解决什么问题?
系统的数据和行为都正确,但接口不符时,我们应该考虑用适配器,目的是使控制范围之外的一个原有对象与某个接口匹配。适配器模式主要用于希望复用一些现存的类,但是接口又与复用环境要求不一致的情况下。
简单的说:我们需要的东西就在面前,可是就是不能使用,又不可以改造他,那么我们就使用适配器模式。
现实生活总的适配器模式很多:电源适配器,只要有电,不管多少伏,使用电源适配器都可以把它变成需要的电压;翻译员,A国家的人听不懂B国家的人的语言,通过一个翻译,就可以明白。这些都是适配器的工作。
## 二、类图
![](https://box.kancloud.cn/2016-02-18_56c5ce7103430.png)
## 三、注意
Adapter与Target是继承关系。
在Adapter的Request方法中调用Adaptee中SpecificRequest方法来实现翻译的目的。
我们在客户端只需要实例化一个Target类型的翻译即可调用Adaptee类。
## 组合模式
## 一、组合模式
将对象组合成树形结构以表示“部分——整体”的层次结构。组合模式使得用户对单个对象和组合对象的使用具有一致性。
组合模式适用范围:树形结构的“部分——整体”的关系中。
## 二、类图
![](https://box.kancloud.cn/2016-02-18_56c5ce7115b19.png)
上图中:Component表示的不是整体,整体也好,部分也罢,Component表示的是他们共有的操作,定义成接口,所以从Component到Composite是聚合关系。
不同看法:
也正因为这样,所以我觉得Client应该和Composite有联系,而不是Component。毕竟Composite中定义的才是具体的物件,在Component中是一些操作。
我的理解是下面这幅图:
![](https://box.kancloud.cn/2016-02-18_56c5ce715f3f9.png)
可以这么理解吗?
- 前言
- 抽象工厂——创建型设计模式一
- 工厂三姐妹——创建型设计模式之二
- 初识面向对象设计模式
- 建造者模式——创建型模式之三
- 原型模式——创建型设计模式四
- 适配器 and 组合模式——结构性模式之一
- 桥接模式——结构性设计模式之二
- 组合模式——结构型设计模式之三
- 装饰模式——结构型设计模式之四
- 外观模式——结构型设计模式之五
- 代理模式——结构型设计模式之六
- 观察者模式——行为型设计模式之五
- 模板设计——行为设计模式之一
- 命令模式——行为设计模式之二
- 状态模式——行为型设计模式之三
- 职责模式——行为设计模式之四
- 中介模式——行为模式之六
- 策略+简单工厂 实战篇
- 看观察者怎么全方位观察机房收费系统
- 登陆也需要装饰——机房收费系统装饰模式实战
- 何为抽象?你有本末倒置吗?
- 再回首,策略、简单工厂是否依然?
- 再回首——行为型设计模式