设计模式:利用C#的Delegate来改进Observer模式.docVIP

设计模式:利用C#的Delegate来改进Observer模式.doc

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
设计模式:利用C#的Delegate来改进Observer模式

专栏作品 设计模式:利用C#的Delegate来改进Observer模式 卢彦 Observer模式简介 为了让更多的人能够看明白本文,所以在此之前,我们先来了解一下Observer模式的基本概念。 模式名称:Observer 结构图: 意图: 定义对象间的一种一对多的依赖关系,当一个对象的状态发生改变时, 所有依赖于它的对象都得到通知并被自动更新。 适用性: 当一个抽象模型有两个方面, 其中一个方面依赖于另一方面。将这二者封装在独立的对象中以使它们可以各自独立地改变和复用。 当对一个对象的改变需要同时改变其它对象, 而不知道具体有多少对象有待改变。 当一个对象必须通知其它对象,而它又不能假定其它对象是谁。换言之, 你不希望这些对象是紧密耦合的。 应用实例 在 编写多层应用程序时,我们通常将表示层和数据逻辑层分隔开,比如很常见的View/Document结构,这种设计方式的好处带来的结果通常是使用多视图 同时表示单一数据源,比如一个Web网站可以方便的同时拥有针对电脑的Html页面和针对手机的WAP页面。使用这种结构时,为了保持数据显示的一致性, 必须要求数据源在数据发生改变时能及时的逐一通知每一个和它绑定的表示层进行更新。但是问题在于数据层本身并不知道到底有多少个不同的表示层正在反映着它 的数据内容。因此需要设计一套有效的机制来完成这个目标。 模式实现 我们先看看来自《设计模式迷你手册》的常规的C#实现代码。 Subject(抽象目标): 目标知道它的观察者。可以有任意多个观察者观察同一个目标。 //实现代码 class Subject { //由于不知道有多少个观察者,所以建立了一个观察者链表 private ArrayList list = new ArrayList(); private string strImportantSubjectData = Initial; public string ImportantSubjectData { get { return strImportantSubjectData; } set { strImportantSubjectData = value; } } public void Attach(Observer o) { list.Add(o); o.ObservedSubject = this; } public void Detach(Observer o) { } public void Notify() { //在数据发生改变后遍历列表通知观察者 foreach (Observer o in list) { o.Update(); } } } Observer(抽象观察者): 为那些在目标发生改变时需要获得通知的对象定义一个更新接口。 abstract class Observer { //内置一个需要观察的对象 protected Subject s; public Subject ObservedSubject { get { return s; } set { s = value; } } abstract public void Update(); } ConcreteSubject(实体目标,在这里相当于数据逻辑层): 将有关状态存入各ConcreteSubject对象。 当它的状态发生改变时,向它的各个观察者发出通知。 //在这里基本上什么都没有做,数据的获取可以放到GetState()里面 class ConcreteSubject : Subject { public void GetState() { } public void SetState() { } } ConcreteObserver(实体观察者,在这里就相当于表示层): 维护一个指向ConcreteSubject的引用。 储存有关状态,这些状态应与目标的状态保持一致。 实现Observer的更新接口以使自身状态与目标状态保持一致。 class ConcreteObserver : Observer { private string observerName; public ConcreteObserver(string name) { observerName = name; } override public void Update() { //将数据显示出来 Console.WriteLine(In Observer {0}: data from subject = {1}, observerName,

文档评论(0)

xcs88858 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

版权声明书
用户编号:8130065136000003

1亿VIP精品文档

相关文档