C#设计模式之观察者
Iron之观察者
引言
上一篇说的职责链模式,很有意思的一个模式,今天这个模式也是很有意思的一个模式,还是不啰嗦了直接进入主题吧。
场景介绍:在上一遍中说到用到部件检测,很巧妙的让调用者和处理者解耦了(没有看过上篇的文章也没关系,只是剧情是要接着发展的),要把部件拿去检测是要让个人来盯着看呢?还是部件生产好了自动就被拿去检测了呢?毋庸置疑必须是自动化的。
看一下部件的结构
/// <summary>
/// 部件
/// </summary>
public class ComponentModel
{
public string Name { get; set; }
public int Value
{
get
{
return ;
}
} }
这个部件还是上一篇的部件,没有做任何改动。只是示例,为了让没看过上一篇的朋友知道。
按照场景里所要求的,定义了下面的两个类型,ComponentModelFactory类型,ComponentModel类型工厂负责生产ComponentModel部件,并且在完成时通知要另外处理部件的对象。
ExecutionCheck类型,就是要要被通知到的对象,它等待着别人告诉它 “有部件生产好了,需要被你送去检测”,不会它会很无聊。
/// <summary>
/// 示例ComponentModel类型工厂 生产了ComponentModel 通知ExecutionCheck对象去检测
/// </summary>
public class ComponentModelFactory
{
public static ComponentModel ComModelFactory()
{
return new ComponentModel();
}
}
/// <summary>
/// 送ComponentModel对象去检测
/// </summary>
public class ExecutionCheck
{
public void ComponentModelCheck(ComponentModel comModel)
{
//送去执行检测
//或者是一些其他操作
}
}
来看看调用代码:
ExecutionCheck executionCheck = new ExecutionCheck();
executionCheck.ComponentModelCheck(ComponentModelFactory.ComModelFactory());
executionCheck.ComponentModelCheck(ComponentModelFactory.ComModelFactory());
executionCheck.ComponentModelCheck(ComponentModelFactory.ComModelFactory());
似乎是解决了问题,但是结果糟透了,虽然executionCheck很高兴,因为它有活干了,我只能以这样的方式去通知executionCheck,或许有人说修改下ComponentModelFactory类型会好一点,我知道是这样的:
public class ComponentModelFactory
{
public static ComponentModel ComModelFactory()
{
return new ComponentModel();
}
public void PastMessage(ComponentModel componentModel,ExecutionCheck executionCheck)
{
executionCheck.ComponentModelCheck(componentModel);
}
}
调用代码则调整为:
ComponentModelFactory componentModelFactory = new ComponentModelFactory();
ExecutionCheck executionCheck=new ExecutionCheck();
componentModelFactory.PastMessage(ComponentModelFactory.ComModelFactory(), executionCheck);
这样的结果,调用方式没问题了,可是ComponentModelFactory类型的内部居然有着这样高的耦合,无法忍受,必须得找出一种方式或者模式来解决这样的难题,不然寝食难安!!!!
定义对象间的一种一对多的依赖关系,当一个对象的状态发生改变时,所有依赖于它的对象都得到通知并被自动更新。
——Gof
按照模式的定义重新来过(会有点不一样的地方中心思想不变),先对ExecutionCheck 类型进行抽象
/// <summary>
/// 抽象的ExecutionCheck(抽象观察者)
/// </summary>
public abstract class ABSExecutionCheck
{
public abstract void ComponentModelCheck(ComponentModel comModel);
} /// <summary>
/// 送ComponentModel对象去检测(观察者)
/// </summary>
public class ExecutionCheck:ABSExecutionCheck
{
public override void ComponentModelCheck(ComponentModel comModel)
{
//送去执行检测
//或者是一些其他操作
}
}
然后再对ComponentModelFactory进行改造,并且抽象它。
/// <summary>
/// 抽象目标
/// </summary>
public abstract class ABSComponentModelFactory
{
protected ABSExecutionCheck absExecutionCheck;
public abstract void RegisterABSExecutionCheck(ABSExecutionCheck executionCheck);
public abstract void ClearABSExecutionCheck();
public abstract void PastMessage(ComponentModel componentModel);
}
ABSComponentModelFactory类型是要让ComponentModelFactory类型实现的,从这里可以看出是遵循设计原则的面对抽象编程的,当然了最后一个PastMessage函数忽略掉,现在来看一下实现了抽象目标ABSComponentModelFactory的ComponentModelFactory(具体目标)的实现。
/// <summary>
/// 示例ComponentModel类型工厂 生产了ComponentModel 通知ExecutionCheck对象去检测 (具体目标)
/// </summary>
public class ComponentModelFactory:ABSComponentModelFactory
{
public static ComponentModel ComModelFactory()
{
return new ComponentModel();
} public override void RegisterABSExecutionCheck(ABSExecutionCheck executionCheck)
{
absExecutionCheck = executionCheck;
} public override void ClearABSExecutionCheck()
{
absExecutionCheck = null;
}
public override void PastMessage(ComponentModel componentModel)
{
absExecutionCheck.ComponentModelCheck(componentModel);
}
}
现在再来看一下调用的代码:
ABSExecutionCheck executionCheck = new ExecutionCheck();
ABSComponentModelFactory componentModelFactory = new ComponentModelFactory();
componentModelFactory.RegisterABSExecutionCheck(executionCheck);
componentModelFactory.PastMessage(ComponentModelFactory.ComModelFactory());
这样就比较稳固了,在第一行new ExecutionCheck()的地方可以动态注入,和最后行的工厂生产对象一样。因为这里只是示例就不会很严谨。 还有要说的就是定义中是一对多,这样可以修改ABSComponentModelFactory类型中的字段,修改为集合类型就可以了。 把对应的实现类也适当的修改一下就可以了。
观察者就讲到这里。下一篇是外观,敬请期待。
C#设计模式之观察者的更多相关文章
- iOS设计模式(01):观察者
iOS设计模式(01):观察者 iOS-Observer-Pattern 什么是观察者模式 什么是观察者模式?你曾经订阅过报纸吗?在订阅报纸的时候,你不用去任何地方,只需要将你的个人地址信息以及订阅信 ...
- 设计模式:观察者(Observer)模式
设计模式:观察者(Observer)模式 一.前言 观察者模式其实最好的名称应该是“发布订阅”模式,和我们现在大数据之中的发布订阅方式比较类似,但是也有区别的地方,在上一个设计模式,我们学习的是仲 ...
- 设计模式之观察者(OBSERVER)模式
定义 定义对象间的一种一对多的依赖关系,当一个对象的状态发生改变时,所有依赖于它的对象都得到通知并被自动更新. Observer模式描述了如何建立这种关系.这一模式中的关键对象是目标(subject ...
- 设计模式笔记-观察者(Observer)
观察者设计模式应该是比较简单的一个设计模式. 定义 定义了对象之间的一对多依赖,这样以来,当一个对象改变状态时,它的所有依赖者都会收到通知并自动更新. 简单理解就是: 当1个对象状态有所改变的时候,依 ...
- js 设计模式:观察者和发布订阅模式
总是把这两个当作同一个模式,但其实是不太一样的,现在重温一下. 观察者模式 观察者直接订阅目标,当目标触发事件时,通知观察者进行更新 简单实现 class Observer { constructor ...
- Head First 设计模式 —— 02. 观察者 (Observer) 模式
思考题 在我们的一个实现中,下列哪种说法正确?(多选) P42 public class WeatherDate { // 实例变量声明 public void measurementsChanged ...
- 设计模式 之 观察者(Observer)模式
观察者(observer)模式定义了一对多的依赖关系,让多个观察者对象能够同时监听某一主题对象.这个主题对象中的状态发生改变时,就会通知所有的观察者对象. 观察者模式的结构图: 结构中各个部分的含义: ...
- 设计模式之观察者(Observer)模式 代码详解
import java.util.ArrayList; import java.util.List; /** * User: HYY * Date: 13-10-28 * Time: 下午1:34 * ...
- Java设计模式——Observer(观察者)模式
在多个对象之间建立一对多的关系,以便当一个对象状态改变的时候.其它全部依赖于这个对象的对象都能得到通知,并被自己主动更新. 适用情况: 当一个抽象模型有两个方面,当中一个方面依赖于还有一方面. 将这二 ...
随机推荐
- Matlab 读取文件夹中所有的bmp文件
将srcimg文件下的bmp文件转为jpg图像,存放在dstimg文件夹下 str = 'srcimg'; dst = 'dstimg'; file=dir([str,'\*.bmp']); :len ...
- iOS多播放器封装
今年在做直播业务的时候遇到一些问题,就是在一个套播放器UI中需要多种不同的播放器(AVPlayer.IJKPlayer.AliPlayer)支持,根据ABTest开关来切换具体使用哪种播放器,并且还要 ...
- 【web maven】新建的项目 controller也有,从前台跳转后台 无法找到对应的controller
碰上很 愣的问题: 使用maven搭建项目完成,项目页面写好,实体.Dao.Service.Controller都有了,但是指定Controller中的某个方法中一直不能从前台进入后台 原因: 没有w ...
- [原创]Centos7 从零配置Nginx+PHP+MySql
序言 这次玩次狠得.除了编译器使用yum安装,其他全部手动编译.哼~ 看似就Nginx.PHP.MySql三个东东,但是它们太尼玛依赖别人了. 没办法,想用它们就得老老实实给它们提供想要的东西. 首先 ...
- WebGL入门教程(五)-webgl纹理
前面文章: WebGL入门教程(一)-初识webgl WebGL入门教程(二)-webgl绘制三角形 WebGL入门教程(三)-webgl动画 WebGL入门教程(四)-webgl颜色 这里就需要用到 ...
- python 爬虫(四)
爬遍整个网络 1 当我们访问整个网络的时候,我们不可避免的会访问不同的网站,但是不同的网站会有完全不同的结构和内容... 现在一步一步的构建访问整个网络的脚本 I 从一个网站开始,每一次都爬向不同的网 ...
- [转]Windows7文件夹转移清理臃肿的C盘
当你使用Windows的时候,你会发现无论哪个版本的Windows,系统都会默认将用户文件夹和程序数据文件夹(xp下是Documents and Settings文件夹,而windows7和vista ...
- Android MVP 利用rxjava 避免向Model传入监听方法
传统的MVP: 1.抽离出View的接口,即ILoginView. 2.抽离Model的接口,即ILoginModel. 3.抽离Presenter的接口,即ILoginPresenter. 4.实现 ...
- jQuery插件开发(溢出滚动)
声明:此程序仅针对手机端,简单的封装一个插件,意在记载插件的开发过程,如有错误及不足之处,还望即时指出. 移动开发的时候,我们经常会遇到滑动事件,众所周知手机端滑动主要依靠touch事件.最近接连遇到 ...
- js中使用new Date(str)创建时间对象不兼容firefox和ie的解决方式
/** * 解决 ie,火狐浏览器不兼容new Date(s) * @param strDate * 返回 date对象 * add by zyf at 2015年11月5日 */ function ...