观察者模式observer不适用于_观察者模式是什么

观察者模式observer不适用于_观察者模式是什么观察者模式Obeserver动机模式定义实例结构图要点总结笔记动机在软件构建过程中,我们需要为某些对象建立 一种“通知依赖关系” —-一个对象发(目标对象)的状态发生改变,所有依赖的对象(观察者对象)都将很好的得到通知。如果这样的依赖关系过于紧密。将使软件不能很好的抵御变化使用面向对象技术 可以将这种依赖关系弱化,并形成一种稳定的依赖关系。从而实现软件体系结构的松耦合。模式定义定义对象间的一种一对多(变化)的依赖关系,以便当一个对象(subject)的状态发生改变时,所有依赖于它的对象都得到通

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

动机

在软件构建过程中,我们需要为某些对象建立 一种“通知依赖关系” —-一个对象发(目标对象)的状态发生改变,所有依赖的对象(观察者对象)都将很好的得到通知。如果这样的依赖关系过于紧密。将使软件不能很好的抵御变化

使用面向对象技术 可以将这种依赖关系弱化,并形成一种稳定的依赖关系。从而实现软件体系结构的松耦合。

模式定义

定义对象间的一种一对多(变化)的依赖关系,以便当一个对象(subject)的状态发生改变时,所有依赖于它的对象都得到通知并自动更新

实例

实现进度条

朴素实现

class MainForm : public Form{ 
   
    TextBox * txtFilaPath;
    TextBox * txtFileNumber;

    ProgressBar *progressBar;
public :
    void Button_Click(){ 
   
        string filePath = txtFilaPath->getText();
        int number = atoi(txtFileNumber->getText());

        FileSplitter splitter(filePath,number,progressBar);

        splitter.split();
    }
}
class FileSpliter{ 
   
    string m_filePath;
    int m_fileNumber;
    ProgressBar *m_progressBar;
public:
    FileSpliter(const string & filePath,int fileNumber,ProgressBar progressbar):
    m_filePath(filePath),
    m_fileNumber(fileNumber),
    m_progressBar(progressbar){ 
   
        
    }
    void split(){ 
   
        //1.读取大文件

        //2.分批向小文件写入
        for(int i = 0;i < m_fileNumber;i ++){ 
   
            //..
            if(m_progressBar != nullptr){ 
   
                m_progressBar->setValue((i + 1) / m_fileNumber);
            }
        }
    }
}

观察者模式实现

class MainForm : public Form, public IProgress{ 
   
    TextBox * txtFilaPath;
    TextBox * txtFileNumber;

    ProgressBar *progressBar;
public :
    void Button_Click(){ 
   
        string filePath = txtFilaPath->getText();
        int number = atoi(txtFileNumber->getText());

        FileSplitter splitter(filePath,number);
        ConsoleNotifier cn;

        splitter.addIProgress(this);
        splitter.addIProgress(this);
        
        splitter.split(&cn);
    }
    virtual void Doprogress(float value){ 
   
        progressBar->setValue(value);
    }
}

class ConsoleNotifier : public IProgress{ 
   
public:
    virtual void DoProgress(float value){ 
   
        cout<<".";
    }
}
//抽象接口
class IProgress{ 
   
    string m_filePath;
public:
    virtual void DoProgress(float value) = 0;
    virtual ~IProgress(){ 
   };
}

class FileSpliter{ 
   
    string m_filePath;
    int m_fileNumber;
    // ProgressBar *m_progressBar; //通知控件
    vector<IProgress *> m_iprogressVector;   //抽象通知机制


public:
    FileSpliter(const string& filePath,int fileNumber):
    m_filePath(filePath),
    m_fileNumber(fileNumber){ 
   
    }
    void add_IProgress(IProgress *iprogress){ 
   
        m_iprogressVector.push_back(iprogress);
    }
    void remove_IProgress(IProgress *iprogress){ 
   
        m_iprogressVector.remove(iprogress);
    }
    void add
    void split(){ 
   
        //1.读取大文件

        //2.分批向小文件写入
        for(int i = 0;i < m_fileNumber;i ++){ 
   
            //..
            float progressValue = (i + 1) / m_fileNumber;
            onProgress(progressValue);
        }
    }
protected:
    void onProgress(float value){ 
   
        vector<IProgress *>::Iterator itor = m_iprogressVector.begin();

        while(itor != m_iprogressList.end()){ 
   
            (*itor)->DoProgress(value); //更新进度条
            itor ++;
        }
    }
}

结构图

要点总结

  • 使用面向对象的抽象,Obeserver模式使得我们可以独立改变目标与观察者,从而使两者之间的关系达到松耦合
  • 目标发送通知时,无需指定观察者,通知(可以携带通知信息作为参数)会自动传播
  • 观察者自己决定是否需要订阅通知,目标对象对此一无所知
  • Obeserver 模式是基于事件UI框架中非常常用的设计模式,也是MVC模式的一个重要组成部分

笔记

  • 违背了依赖倒置原则 高层不能依赖底层 高层和底层都应该依赖于抽象 抽线不能依赖实现 实现应该依赖抽象
  • 依赖:指的是编译时依赖 A依赖B B必须存在 A才能通过编译
  • 独立一般指 你变我不变 松耦合
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/169044.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 页面置换算法实验报告c语言(大一c语言课程设计计算器)

    在进程运行过程中,如果它需要访问的页面不在内存,需要把它调入内存,但是内存已满时,需要把内存中的某页数据送到磁盘的对换区中。而选择哪个页面,则由固定的算法来决定,称为页面置换算法

    2022年4月18日
    41
  • mybatis的二级缓存_mybatis的一级缓存

    mybatis的二级缓存_mybatis的一级缓存上次谈到了mybatis一级缓存实际上是SqlSession级别的缓存,多个SqlSession并不共享,针对这种情况,我们可以使用mybatis二级缓存来处理。1.mybatis二级缓存是什么mybatis二级缓存是mybatis的另一种缓存机制,区别于一级缓存,它是namespace级别,即一个mapper一个缓存,相互独立,互不影响。默认不开启,需要配置开启。同一namespace下的多个sqlSession可以共享缓存,大体结构如下图2.二级缓存生效的条件同一个namespa.

    2022年9月20日
    2
  • Softmax classifier[通俗易懂]

    Softmax classifier[通俗易懂]Softmaxclassifier原文链接SVM是两个常见的分类器之一。另一个比较常见的是Softmax分类器,它具有不同的损失函数。如果你听说过二分类的Logistic回归分类器,那么Softmax分类器就是将其推广到多个类。不同于SVM将 f(xi,W) 的输出结果 (为校准,可能难以解释)作为每个分类的评判标准,Softmax分类器给出了一个稍直观的输出(归一化的类概率),并且也有

    2025年8月25日
    4
  • pytest skipif_pytest conftest.py文件

    pytest skipif_pytest conftest.py文件前言pytest.mark.skip可以标记无法在某些平台上运行的测试功能,或者您希望失败的测试功能Skip和xfail:处理那些不会成功的测试用例你可以对那些在某些特定平台上不能运行的测试用

    2022年7月30日
    9
  • 淘宝、天猫、京东、苏宁等平台抢购脚本

    淘宝、天猫、京东、苏宁等平台抢购脚本淘宝、天猫、京东、苏宁等平台抢购脚本扫码添加“SevenBlog”公众号,获取更多好玩脚本进入正题:建议使用Chrome浏览器1、安装浏览器插件,Ghelper(需要注册账号)打开浏览器扩展程序,并且打开开发者模式,将下载好的Ghelper解压,然后添加已解压的扩展程序2、浏览器地址栏输入chrome://apps/,并打开下面的网上应用店…

    2022年6月7日
    54
  • 企业网站制作的决定因素「建议收藏」

    企业网站制作的决定因素「建议收藏」企业在进行网站建站的过程中要需要很多网站相关行的内容,如何建站?我们从哪些方面将网站建设好呢?现在只要懂网页三剑客,有一台电脑、懂点技术就可以做网站了,面对现在参差不齐的建站公司,我们方如何选择,哪些因素是我们应关注的?下面就为大家谈谈几点: 因素一:网站的易用性以前找网络公司,做出的网站管理后台功能简单,导致后期维护、修改和扩展困难,甚至只能付费让制作公司维护,有一些公司制作的网站

    2025年6月19日
    5

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号