【设计模式】观察者模式

举例:

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

}
相关推荐
智者知已应修善业31 分钟前
【求等差数列个数/无序获取最大最小次大次小】2024-3-8
c语言·c++·经验分享·笔记·算法
LYFlied1 小时前
【每日算法】LeetCode 416. 分割等和子集(动态规划)
数据结构·算法·leetcode·职场和发展·动态规划
多米Domi0111 小时前
0x3f 第19天 javase黑马81-87 ,三更1-23 hot100子串
python·算法·leetcode·散列表
历程里程碑1 小时前
滑动窗口最大值:单调队列高效解法
数据结构·算法·leetcode
課代表2 小时前
从初等数学到高等数学
算法·微积分·函数·极限·导数·积分·方程
ullio2 小时前
arc206d - LIS ∩ LDS
算法
等等小何2 小时前
leetcode1593拆分字符串使唯一子字符串数目最大
算法
王老师青少年编程3 小时前
2025年12月GESP(C++二级): 环保能量球
c++·算法·gesp·csp·信奥赛·二级·环保能量球
weixin_433417673 小时前
Canny边缘检测算法原理与实现
python·opencv·算法
CoderCodingNo3 小时前
【GESP】C++五级真题(贪心思想考点) luogu-P11960 [GESP202503 五级] 平均分配
开发语言·c++·算法