【设计模式】观察者模式

举例:

小王借了好多钱,分别问boss1,boss2,boss3借钱,但是小王暂时没有能力还钱,如果小王有钱的话,就会通知债主,让债主来要钱。

类的实现

c 复制代码
class Creditor//债主类
{
 public:
 virtual void takemoney()=0; 
 virtual  ~Creditor();

};
class debtor
{
 public:
 virtual  ~debtor();
 virtual void Borrow(Creditor*cred)=0;
 virtual void notifyallcreditor()=0;//通知债主使用takemoney函数

}
c 复制代码
class xiaowang: public debtor
{
public:

 void Borrow(Creditor*cred)override//问谁借钱了,就把他记录下来
{
  allcreaditor.push_back(cred);

}

void notifyallcreditor()override//通知债主要钱
{
   for(auto e:allcreaditor)
   {
      e->takemoney();


   }

}

vector<Creditor*>allcreaditor;

}
c 复制代码
class boss1:public Creditor
{
    public:
void takemoney()override
{

cout<<"boss 1要钱"<<endl;

}



};
class boss2:public Creditor
{
    public:
void takemoney()override
{

cout<<"boss 2要钱"<<endl;

}



};
class boss3:public Creditor
{
    public:
void takemoney()override
{

cout<<"boss 3要钱"<<endl;

}



};
c 复制代码
int main()
{
  xiaowang x1;
  boss1 x2;
  boss2 x3;
  boss3 x4;
  x1.Borrow(&x1);
  x1.Borrow(&x2);
  x1.Borrow(&x3);
  x1.notifyallcreditor();

}

完整代码:

c 复制代码
#include<iostream>
#include "vector"
using namespace std;
class Creditor
{
 public:
 virtual void takemoney()=0; 
 virtual ~Creditor(){};

};
class debtor
{
 public:
 virtual  ~debtor(){};
 virtual void Borrow(Creditor*cred)=0;
 virtual void notifyallcreditor()=0;

};
class xiaowang: public debtor
{
public:

 void Borrow(Creditor*cred)override
{
  allcreaditor.push_back(cred);

}

void notifyallcreditor()override
{
   for(auto e:allcreaditor)
   {
      e->takemoney();


   }

}
private:
vector<Creditor*> allcreaditor;

};
class boss1:public Creditor
{
    public:
void takemoney()override
{

cout<<"boss 1要钱"<<endl;

}



};
class boss2:public Creditor
{
    public:
void takemoney()override
{

cout<<"boss 2要钱"<<endl;

}



};
class boss3:public Creditor
{
    public:
void takemoney()override
{

cout<<"boss 3要钱"<<endl;

}

};
int main()
{
  xiaowang x1;
  boss1 x2;
  boss2 x3;
  boss3 x4;
  x1.Borrow(&x2);
  x1.Borrow(&x3);
  x1.Borrow(&x4);
  x1.notifyallcreditor();

}
相关推荐
yu_anan111几秒前
CTC Prefix Score计算
算法·机器学习
Stardep2 分钟前
算法入门21——二分查找算法——山脉数组的峰顶索引
数据结构·算法·leetcode
mjhcsp3 分钟前
P3145 [USACO16OPEN] Splitting the Field G(题解)
开发语言·c++·算法
空空潍3 分钟前
hot100-合并区间(day14)
c++·算法·leetcode
橘颂TA5 分钟前
【剑斩OFFER】算法的暴力美学——力扣 675 题:为高尔夫比赛砍树
数据结构·算法·c·结构与算法
rit84324996 分钟前
UVE算法提取光谱特征波长的MATLAB实现与应用
开发语言·算法·matlab
是娇娇公主~6 分钟前
算法——【最大子数组和】
数据结构·c++·算法
tkevinjd8 分钟前
力扣hot100-283移动零(盲人拉屎)
算法·leetcode
POLITE312 分钟前
Leetcode 94. 二叉树的中序遍历 104. 二叉树的最大深度 226. 翻转二叉树 101. 对称二叉树 (Day 13)
算法·leetcode·职场和发展
老鼠只爱大米15 分钟前
LeetCode经典算法面试题 #2:两数相加(迭代法、字符串修改法等多种实现方案详解)
算法·leetcode·链表·两数相加·字符串修改法·两数相减·大数运算