【设计模式】观察者模式

举例:

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

}
相关推荐
tankeven7 分钟前
HJ158 挡住洪水
c++·算法
Wect22 分钟前
LeetCode 190. 颠倒二进制位:两种解法详解
前端·算法·typescript
刘永鑫Adam26 分钟前
BiB | 蒋超实验室开发 Kun-peng(鲲鹏):实现可扩展且准确的泛域宏基因组分类
人工智能·算法·机器学习·分类·数据挖掘
ltl32 分钟前
SM3 vs SHA-256:两个哈希函数的设计哲学与性能实测
后端·算法
知星小度S37 分钟前
算法训练之递归(一)
数据结构·算法
未来之窗软件服务42 分钟前
SenseVoicecpp ggml-webgpu大模型[AI人工智能(七十五)]—东方仙盟
c++·人工智能·算法·仙盟创梦ide·东方仙盟
ZPC82101 小时前
ROS 2 手眼标定完整方案
人工智能·算法·性能优化·机器人
Q741_1471 小时前
每日一题 力扣 3418. 机器人可以获得的最大金币数 力扣 215. 数组中的第K个最大元素 动态规划 TopK问题 C++ 题解
c++·算法·leetcode·动态规划·topk
Frostnova丶1 小时前
LeetCode 3418.机器人可以获得的最大金币数
算法·leetcode
寻寻觅觅☆1 小时前
东华OJ-基础题-31-素数(C++)
开发语言·c++·算法