【设计模式】观察者模式

举例:

小王借了好多钱,分别问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();

}
相关推荐
汉克老师1 分钟前
GESP2025年9月认证C++四级( 第三部分编程题(1)排兵布阵)
c++·算法·gesp4级·gesp四级
(●—●)橘子……5 分钟前
记力扣2009:使数组连续的最少操作数 练习理解
数据结构·python·算法·leetcode
GalaxyPokemon8 分钟前
LeetCode - 1171.
算法·leetcode·链表
budingxiaomoli34 分钟前
算法---双指针一
算法
iナナ36 分钟前
Java优选算法——位运算
java·数据结构·算法·leetcode
热爱生活的猴子39 分钟前
算法279. 完全平方数
算法·深度优先
sali-tec1 小时前
C# 基于halcon的视觉工作流-章45-网格面划痕
开发语言·算法·计算机视觉·c#
通信小呆呆1 小时前
5G NR 信号检测:从 PSS 相关到 SSB 栅格恢复
算法·5g
Han.miracle2 小时前
数据结构二叉树——层序遍历&& 扩展二叉树的左视图
java·数据结构·算法·leetcode
筱砚.2 小时前
【数据结构——最小生成树与Kruskal】
数据结构·算法