适配器 蒙面模式 代理模式

这次我把适配器,代理模式,蒙面模式敲了,终于理解了这是怎么回事。C++的设计模式实际上就是软件的功能架构,她想办法处理好类与类之间的关系,让软件好用,易操作,方便修改。软件的所遵循的原则是开闭原则,意思就是开放接口,关闭修改,我们可以去扩展;说到扩展就要提及到这六个字“高内聚,低耦合”,我们尽可能的要将功能单一化,一个模块写一个功能,那么我们需要改哪一个功能只需要找到相应就可以,这样做也容易扩展,我增一个功能进来也很easy,举个例子来说吧,假如说一个汽车,我们把汽车可以分为多个模块,发动机,备胎,座位。。。。。。还有很多很多,如果说我的发动机坏了,我仅仅需要把发动机打开,进行修理,而不需要看备胎,座位怎么回事,这就是低耦合,他们之间没有多大的联系,互相独立的模块,低耦合了,一定就高内聚了。其次呢,一定还要注意面向对象编程。

好了说适配器吧,这就是一个兼容模式,通过第三方类库实现软件功能。我没有的函数模块,可是你有啊,我给你钱直接把你的拿来用,就是这么简单

#include <iostream>
using namespace std;

class Adaptee{
	public:
		void Request(){
			cout<<"我调用一下第三方类的方法"<<endl;
		}
    };

// 一定要先定义后使用

class Base{
	public:
	  virtual void process()=0;
};
class Derived:public Base{

};
class Adapter:public Base{
	private:
		Adaptee a;
	public:
		void process(){
		 a.Request();
		}
};

int main(int argc, char** argv) {
	Base *pBase = new Adapter();
	pBase->process();
	delete pBase;

	return 0;
}

运行结果演示

蒙面模式吧 感觉这就像个面子工程,把表面工作做好,她强调的仅仅是顺序问题,比如说你去餐厅吃饭,服务员肯定要安排好上菜的顺序,不可能你做在桌子上还没吃汤就端上来了,  而蒙面模式就干了个这事情。这几个模式比较简单吧,没有什么难度,反正至少要学会21中模式

这个代码就是很难扩展,这就违背了所谓的开闭原则,我每次要增加一个功能的时候,我还要打开Facade去天添加派生类的对象指针,这就有点烦了吧,孩纸,肯定不能这样做,反正事情就是由难,复杂,慢慢猜优化的。

#include <iostream>
#include<vector>

using namespace std;

class Abstractproduct{
	public:
		virtual void production()=0;
};
class productA:public Abstractproduct{
	public:
		void production(){
			cout<<"productA的productionB正在运行"<<endl;
		}
};
class productB:public Abstractproduct{
	public:
		void production(){
			cout<<"productB的productionB正在运行"<<endl;
		}
};
class productC:public Abstractproduct{
	public:
		void production(){
			cout<<"productC的productionC正在运行"<<endl;
		}
};
class Facade{
	private:
		productA *pA;
		productB *pB;
		productC *pC;
	public:
	    Facade(productA *ta,productB *tb,productC *tc){
	    	pA=ta;
	    	pB=tb;
	    	pC=tc;
	    }
		void production(){
		     pB->production();
			 pC->production();
			 pA->production();
		}
};
int main(int argc, char** argv) {

    	productC *pC = new productC();
    	productA *pA = new productA();
    	productB *pB = new productB();

        Facade *pfc = new Facade(pA,pB,pC);

        pfc->production();

        delete pA;
        delete pB;
        delete pC;
        delete pfc;

	return 0;
}

我们队这个代码进行进行优化,我们增加一个vector,我们就用基类指针搞定她,你添加一个,我创建一个基类指针,最后在用一个迭代器逐个输出就好,顺序有客户端决定

#include <iostream>
#include<vector>

using namespace std;

//基类 Abstractproduct
class Abstractproduct{
	public:
		virtual void production()=0;
};
//派生类  productA
class productA:public Abstractproduct{
	public:
		void production(){
			cout<<"productA的productionB正在运行"<<endl;
		}
};
//派生类  productB
class productB:public Abstractproduct{
	public:
		void production(){
			cout<<"productB的productionB正在运行"<<endl;
		}
};
//派生类  productC
class productC:public Abstractproduct{
	public:
		void production(){
			cout<<"productC的productionC正在运行"<<endl;
		}
};
// 蒙面模式  只管调用的顺序
class Facade{
	private:
		vector<Abstractproduct *>vec;
	public:
		void add(Abstractproduct *t){
			vec.push_back(t);
		}
		void production(){
		  vector<Abstractproduct *>::iterator it;
		  for(it=vec.begin();it!=vec.end();it++)
		      (*it)->production();

		}
};
int main(int argc, char** argv) {

    	productC *pC = new productC();
    	productA *pA = new productA();
    	productB *pB = new productB();

        Facade *pfc = new Facade();

        pfc->add(pB);
        pfc->add(pC);
        pfc->add(pA);
        pfc->production();

        delete pA;
        delete pB;
        delete pC;
        delete pfc;

	return 0;
}

演示结果

第三种说代理模式吧,他仅仅是有个代理,一般而言代理很纯洁,他没有什么功能,比如,情人节我要给女朋友送花 ,可是我很忙,这个时候我们就需要代理,帮我送花,但是要记住花“实际上”我在送,而不是代理。相信有人听说过代理服务器吧,我仅仅吧一分部功能让出去,让代理完成就好。1989年南斯拉夫大使馆事件,我们4万中国人攻陷美国白宫网站,网站一上去后面一个大大的五星红旗,那种自豪,懂就好,可是人家解决服务器奔溃这件事人家还不到两分钟,我们很高兴的原来只是把人家的代理服务器功奔溃了,所以嘛,代理还是很重要滴,我在写代理的时候出现了,一个严重问题,就是严重的典型的指针问题,我的指针没有指向,只是看起来是对的而已,实际上是错的

我的错误代码,编译可以通过,但是运行直接奔溃,

<span style="font-size:18px;">#include <iostream>
using namespace std;

class Base{
	public:
		virtual void fun()=0;
		virtual ~Base(){}
};
class Proxy:public Base{
	private:
		Base *pBase;
	public:
		void fun(){
			pBase->fun();
		}
		~Proxy(){}
};
class Derived:public Base{
	public:
		void fun(){
			cout<<"调用Derived的fun()了"<<endl;
		}
		~Derived(){}
};
int main(int argc, char** argv) {

	Proxy *pProxy;

	pProxy->fun();

	return 0;
}</span>

所以嘛,不要嫌麻烦么,简单和麻烦是相对的,我恶魔呢尽可能的吧客户端简单,那么里面的代码就越复杂

我吧修改之后的发上去

#include <iostream>
#include<vector>

using namespace std;

class Abstractproduct{
	public:
		virtual void production()=0;
};
class productA:public Abstractproduct{
	public:
		void production(){
			cout<<"productA的productionB正在运行"<<endl;
		}
};
class productB:public Abstractproduct{
	public:
		void production(){
			cout<<"productB的productionB正在运行"<<endl;
		}
};
class productC:public Abstractproduct{
	public:
		void production(){
			cout<<"productC的productionC正在运行"<<endl;
		}
};
class Facade{
	private:
		productA *pA;
		productB *pB;
		productC *pC;
	public:
	    Facade(productA *ta,productB *tb,productC *tc){
	    	pA=ta;
	    	pB=tb;
	    	pC=tc;
	    }
		void production(){
		     pB->production();
			 pC->production();
			 pA->production();
		}
};
int main(int argc, char** argv) {

    	productC *pC = new productC();
    	productA *pA = new productA();
    	productB *pB = new productB();

        Facade *pfc = new Facade(pA,pB,pC);

        pfc->production();

        delete pA;
        delete pB;
        delete pC;
        delete pfc;

	return 0;
}

如果有什么问题,欢迎指正,本人菜鸟一枚

时间: 2024-10-12 23:43:56

适配器 蒙面模式 代理模式的相关文章

蓝懿IOS委托模式代理模式

今天刘国斌老师讲了有关oc语言里的委托模式(代理模式),通过了一个打地鼠的游戏讲解了委托模式的功能作用,之后连带讲解了协议的书写和使用. 打地鼠功能包括屏幕随机出现地鼠,点击消失,如果不点击5秒后自动消失,屏幕右上角有一个label显示点击的数量:编写思维是,首先在文件里粗昂见一个类,在类里重写init方法,加上每.5秒出现的事件,倒入viewcontroler文件,在地鼠类里声明一个属性delegate,在button点击事件加上创建对象点delegate调用viewcontroler里的加分

第14章 结构型模式—代理模式

1. 代理模式(Proxy Pattern)的定义 (1)为其他对象提供一种代理以控制对这个对象的访问 ①代理模式在客户和被客户访问的对象之间,引入了一定程度的间接性,客户是直接使用代理,让代理来与被访问的对象进行交互. ②这种附加的间接性增加了灵活性和不同的用途. (2)代理模式的结构和说明 ①Proxy:代理对象,通常实现与具体的目标对象一样的接口,这样就可以使用代理来代替具体的目标对象. A.保存一个指向具体目标对象的指针,可以在需要的时候调用具体的目标对象,若RealSubject和Su

Proxy模式 代理模式

Android的 LocalWindowManager 和 WindowManagerImgl 都实现了WindowManager接口.LocalWindowManager 中保存一个WindowManagerImgl的对象,并将这个对象通过构造对象返回. 即将它的工作委托 WindowManagerImgl 来完成.使用了代理模式 1.概述 因为某个对象消耗太多资源,而且你的代码并不是每个逻辑路径都需要此对象, 你曾有过延迟创建对象的想法吗 ( if和else就是不同的两条逻辑路径) ? 你有

13 结构型模式-----代理模式

模式动机(Proxy Pattern):引入一个代理对象负责对真实对象的访问.将代理对象和真实对象的公共接口提取出来,用Subject接口表示.具体结构图及其分析如下: 模式结构图: 模式代码: bt_代理模式.h: 1 #ifndef PP_H 2 #define PP_H 3 #include <iostream> 4 using namespace std; 5 6 /* 7 抽象主题类,定义了RealSubject和Proxy的公共接口,这样就可以在 8 使用RealSubject的地

设计模式之Proxy模式(代理模式)

代理模式很容易理解,就是代替别人去做某一件事,打个比方,我们需要买水果,一般是去超市或者水果店买水果,很少有人去果园买水果,果园是生产水果的地方,但很少出售水果,在这里,水果店,超市就成了代理. 首先定义一个抽象类,提供所有的函数接口. 定义卖水果的抽象类,也就是接口,果园与超市都要继承这个类. #pragma once class CSellFruits//定义一个抽象类 { public: CSellFruits(void); virtual ~CSellFruits(void); virt

软件架构模式--代理模式

代理模式用于在结构化系统中对组件解耦.系统内各组件间采用远过程调用的方式交互.代理(组件充当组件间通讯的协调角色.提供服务的组件将其能力(服务以及特性)发布给代理,客户端均向代理请求服务,由代理将请求重定向到先前已发布过对应服务的组件进行处理. 代理模式在软件架构上具有非常明显的特点,优点与缺点都是十分的突出.代理模式的优点就是通过一个代理对象完成一系列的处理,在将来的程序改动中,就会允许动态更改.添加.删除和重新定位对象,这使开发人员的发布变得透明,符合开闭原则.代理模式能够协调调用者和被调用

软件构架模式——代理模式介绍

什么是代理模式? 来张图: 1.代理模式适用于什么场景? 直接访问一个组件通常是不合适的.我们不想将物理地址强制编码到客户机,对组件直接和无限制的访问可能是低效的或者不安全的,所以就需要额外的控制机制. 所以,让客户机通过组件代表访问,而不是通过组件本身,这种中间的代表组件----就称为代理---提供组件的接口并执行附加的前期处理和后期处理. 代理提供了原件相同的接口,而且保证了对原件的正确访问.为完成这种功能,代理保持对它所表示的原件的引用. 2.代理需要实现什么功能: 当客户机执行它的任务时

代理模式(Proxy Pattern)

一.概述在软件开发中,有些对象由于创建成本高.访问时需要与其它进程交互等原因,直接访问会造成系统速度慢.复杂度增大等问题.这时可以使用代理模式,给系统增加一层间接层,通过间接层访问对象,从而达到隐藏系统复杂性.提高系统性能的目的.二.代理模式代理模式为其他对象提供一种代理以控制对这个对象的访问.其结构图如下: Subject定义了RealSubject和Proxy共用的接口,使得在任何使用RealSubject的地方都可以使用Proxy abstract class Subject { publ

Android设计模式之代理模式 Proxy

一.概述 代理模式也是平时比较常用的设计模式之一,代理模式其实就是提供了一个新的对象,实现了对真实对象的操作,或成为真实对象的替身.在日常生活中也是很常见的.例如A要租房,为了省麻烦A会去找中介,中介会替代A去筛选房子,A坐享中介筛选的结果,并且交房租也是交给中介,这就是一个典型的日常生活中代理模式的应用.平时打开网页,最先开到的一般都是文字,而图片等一些大的资源都会延迟加载,这里也是使用了代理模式. 代理模式的组成: Abstract Subject:抽象主题-声明真实主题和代理主题共同的接口