设计模式(十五)——接口隔离模式-adapter

对象模式所属类别简介

接口隔离模式包括:facade、proxy、adapter、mediator
采用一层隔离层来解决类之间错乱依赖。

对象模式所属类别简介
adapter-适配器模式

当前模式简介动机

由于应用环境的变化,将一些对象的使用用在新的环境上,但是新的环境可能不适合这些对象。如何利用原有的对象,满足新环境的需求?

需求

在windows系统上,类A的行为只有DoTask

设计一

需求更改

现在增加mac,现在类A还是有DoTask,但是除了有DoTask还有打印hello操作。如何才能继续继续用之前类A的DoTask。

设计一更改版本

违反原则

设计二

class IA  //旧
{
public:
	virtual void DoTask() = 0;
};

class CA: public IA  //旧
{
public:
	virtual void DoTask() { std::cout <<"dotask" << std::endl; }
};

int main() //调用
{
	CA *t =new CA;
	t->DoTask();
	return 0;
}
//打印
dotask

设计二更改版本

#include "stdafx.h"
#include <iostream>
using namespace std;

class IA  //旧
{
public:
	virtual void DoTask() = 0;
};


class CA: public IA  //旧
{
public:
	virtual void DoTask() { std::cout <<"dotask" << std::endl; }
};
////////////////////////////////////////////
class IB  //新
{
public:
	virtual void DoTask() = 0;
};
//对象适配器
class CADapt: public IB  //新
{
public:
	IA *m_ia;
	CADapt(IA *ia) { this->m_ia = ia; }
	virtual void DoTask() {  this->m_ia->DoTask(); std::cout << "hello"<<std::endl; }
};

//类适配器
class CADapt2: public IB, protected CA  //新
{
public:
	IA *m_ia;
	CADapt2(IA *ia) { this->m_ia = ia; }
	virtual void DoTask() {  this->m_ia->DoTask();std::cout << "hello"<<std::endl;  }
};
//////////////////////////////////////////////////////////////
int main() //调用
{
	//对象适配器
	IA *t =new CA;
	IB *t2 = new CADapt(t);
	t2->DoTask();
	//类适配器
	CADapt2 *t3=new CADapt2(t);
	t3->DoTask();
	return 0;
}
//打印
dotask
hello
dotask
hello

设计二比设计一区别

模式定义

将一个类的接口转换成客户希望的另一个接口。Adapter模式使得原本由于接口不兼容而不能一起工作的那些类可以一起工作。(把原来的类传入新的类,新的类复用原来类的行为。)

模式结构

在这里插入图片描述

要点总结

希望复用一些现存的类,但是接口又与复用环境要求不一样。
分为类适配器和对象适配器。类适配器使用多继承,不推荐;对象适配器使用对象组合方式。

在这里插入图片描述

Adapter是新的类,adaptee是旧的,组合起来

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章