乐在其中设计模式(C#) - 观察者模式(Observer Pattern)

简介:
[索引页]
[源码下载]


乐在其中设计模式(C#) - 观察者模式(Observer Pattern)


作者: webabcd


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


示例
有一个Message实体类,某些对象对它的操作有Insert()方法,当发生某些改变的时候,通知所有这些对象并执行Insert()方法。
 
MessageModel
using System; 
using System.Collections.Generic; 
using System.Text; 
 
namespace Pattern.Observer 

         /// <summary> 
         /// Message实体类 
         /// </summary> 
         public  class MessageModel 
        { 
                 /// <summary> 
                 /// 构造函数 
                 /// </summary> 
                 /// <param name="msg">Message内容</param> 
                 /// <param name="pt">Message发布时间</param> 
                 public MessageModel( string msg, DateTime pt) 
                { 
                         this._message = msg; 
                         this._publishTime = pt; 
                } 
 
                 private  string _message; 
                 /// <summary> 
                 /// Message内容 
                 /// </summary> 
                 public  string Message 
                { 
                        get {  return _message; } 
                        set { _message = value; } 
                } 
 
                 private DateTime _publishTime; 
                 /// <summary> 
                 /// Message发布时间 
                 /// </summary> 
                 public DateTime PublishTime 
                { 
                        get {  return _publishTime; } 
                        set { _publishTime = value; } 
                } 
        } 
}
 
IMessage
using System; 
using System.Collections.Generic; 
using System.Text; 
 
namespace Pattern.Observer 

         /// <summary> 
         /// 操作Message的接口(Observer) 
         /// </summary> 
         public  interface IMessage 
        { 
                 /// <summary> 
                 /// 插入Message 
                 /// </summary> 
                 /// <param name="mm">Message实体对象</param> 
                 /// <returns></returns> 
                 string Insert(MessageModel mm); 
        } 
}
 
SqlMessage
using System; 
using System.Collections.Generic; 
using System.Text; 
 
namespace Pattern.Observer 

         /// <summary> 
         /// Sql方式操作Message(ConcreteObserver) 
         /// </summary> 
         public  class SqlMessage : IMessage 
        { 
                 /// <summary> 
                 /// 插入Message 
                 /// </summary> 
                 /// <param name="mm">Message实体对象</param> 
                 /// <returns></returns> 
                 public  string Insert(MessageModel mm) 
                { 
                         return  "sql方式:" + mm.Message +  " " + mm.PublishTime.ToString(); 
                }    
        } 
}
 
XmlMessage
using System; 
using System.Collections.Generic; 
using System.Text; 
 
namespace Pattern.Observer 

         /// <summary> 
         /// Xml方式操作Message(ConcreteObserver) 
         /// </summary> 
         public  class XmlMessage : IMessage 
        { 
                 /// <summary> 
                 /// 插入Message 
                 /// </summary> 
                 /// <param name="mm">Message实体对象</param> 
                 /// <returns></returns> 
                 public  string Insert(MessageModel mm) 
                { 
                         return  "xml方式:" + mm.Message +  " " + mm.PublishTime.ToString(); 
                }    
        } 
}
 
AbstractMessageSubject
using System; 
using System.Collections.Generic; 
using System.Text; 
 
namespace Pattern.Observer 

         /// <summary> 
         /// 抽象Message主题(Subject) 
         /// </summary> 
         public  abstract  class AbstractMessageSubject 
        { 
                 private MessageModel _messageModel; 
                 private List<IMessage> list =  new List<IMessage>(); 
 
                 /// <summary> 
                 /// 构造函数 
                 /// </summary> 
                 /// <param name="mm">Message实体对象</param> 
                 public AbstractMessageSubject(MessageModel mm) 
                { 
                         this._messageModel = mm; 
                } 
 
                 /// <summary> 
                 /// 添加一个实现IMessage接口的对象 
                 /// </summary> 
                 /// <param name="m">实现IMessage接口的对象</param> 
                 public  void Attach(IMessage m) 
                { 
                        list.Add(m); 
                } 
 
                 /// <summary> 
                 /// 移除一个实现IMessage接口的对象 
                 /// </summary> 
                 /// <param name="m">实现IMessage接口的对象</param> 
                 public  void Detach(IMessage m) 
                { 
                        list.Remove(m); 
                } 
 
                 /// <summary> 
                 /// 通知所有观察者 
                 /// </summary> 
                 /// <returns></returns> 
                 public  string Notify() 
                { 
                         string s = ""; 
                         foreach (IMessage i  in list) 
                        { 
                                s += i.Insert(_messageModel); 
                                s +=  "<br />"
                        } 
 
                         return s; 
                } 
 
                 /// <summary> 
                 /// Message发布时间 
                 /// </summary> 
                 public DateTime PublishTime 
                { 
                        get {  return _messageModel.PublishTime; } 
                        set 
                        { 
                                _messageModel.PublishTime = value; 
                                Notify(); 
                        } 
                } 
        } 
}
 
MessageSubject
using System; 
using System.Collections.Generic; 
using System.Text; 
 
namespace Pattern.Observer 

         /// <summary> 
         /// Message主题(ConcreteSubject) 
         /// </summary> 
         public  class MessageSubject : AbstractMessageSubject 
        { 
                 /// <summary> 
                 /// 构造函数 
                 /// </summary> 
                 /// <param name="mm">Message实体对象</param> 
                 public MessageSubject(MessageModel mm) 
                        :  base(mm) 
                { 
    
                } 
        } 
}
 
Test
using System; 
using System.Data; 
using System.Configuration; 
using System.Collections; 
using System.Web; 
using System.Web.Security; 
using System.Web.UI; 
using System.Web.UI.WebControls; 
using System.Web.UI.WebControls.WebParts; 
using System.Web.UI.HtmlControls; 
 
using Pattern.Observer; 
 
public partial  class Observer : System.Web.UI.Page 

         protected  void Page_Load( object sender, EventArgs e) 
        { 
                MessageSubject m =  new MessageSubject( new MessageModel( "插入Message", DateTime.Now)); 
 
                SqlMessage sqlMessage =  new SqlMessage(); 
                XmlMessage xmlMessage =  new XmlMessage(); 
 
                m.Attach(sqlMessage); 
                m.Attach(xmlMessage); 
 
                 // System.Threading.Thread.Sleep(1000); 
                 // 修改了PublishTime就会通知所有观察者 
                 // m.PublishTime = DateTime.Now; 
                 
                Response.Write(m.Notify()); 
        } 
}
 
 
运行结果
sql方式:插入Message 2007-5-26 9:38:18
xml方式:插入Message 2007-5-26 9:38:18


参考
http://www.dofactory.com/Patterns/PatternObserver.aspx


OK
[源码下载]



     本文转自webabcd 51CTO博客,原文链接: http://blog.51cto.com/webabcd/344584 ,如需转载请自行联系原作者
相关文章
|
设计模式 消息中间件 安全
C# 一分钟浅谈:观察者模式与订阅发布模式
【10月更文挑战第11天】本文介绍了观察者模式和订阅发布模式,这两种设计模式主要用于实现对象间的解耦。观察者模式通过事件和委托实现一个对象状态改变时通知多个依赖对象;订阅发布模式则通过事件聚合器实现发布者与订阅者之间的解耦。文章详细探讨了这两种模式的实现方式、常见问题及避免方法,帮助开发者在实际项目中更好地应用这些模式,提升代码的可维护性和扩展性。
299 1
|
8月前
|
设计模式 消息中间件 存储
【设计模式】【行为型模式】观察者模式(Observer)
一、入门 什么是观察者模式? 观察者模式(Observer Pattern)是一种行为设计模式,它定义了对象之间的一对多依赖关系,当一个对象的状态发生改变时,所有依赖于它的对象都会收到通知并自动更新。
419 9
|
10月前
|
设计模式 Java 数据安全/隐私保护
Java 设计模式:装饰者模式(Decorator Pattern)
装饰者模式属于结构型设计模式,允许通过动态包装对象的方式为对象添加新功能,提供比继承更灵活的扩展方式。该模式通过组合替代继承,遵循开闭原则(对扩展开放,对修改关闭)。
设计模式-工厂模式 Factory Pattern(简单工厂、工厂方法、抽象工厂)
这篇文章详细解释了工厂模式,包括简单工厂、工厂方法和抽象工厂三种类型。每种模式都通过代码示例展示了其应用场景和实现方法,并比较了它们之间的差异。简单工厂模式通过一个工厂类来创建各种产品;工厂方法模式通过定义一个创建对象的接口,由子类决定实例化哪个类;抽象工厂模式提供一个创建相关或依赖对象家族的接口,而不需要明确指定具体类。
设计模式-工厂模式 Factory Pattern(简单工厂、工厂方法、抽象工厂)
|
设计模式 安全 Java
C# 一分钟浅谈:设计模式之单例模式
【10月更文挑战第9天】单例模式是软件开发中最常用的设计模式之一,旨在确保一个类只有一个实例,并提供一个全局访问点。本文介绍了单例模式的基本概念、实现方式(包括饿汉式、懒汉式和使用 `Lazy&lt;T&gt;` 的方法)、常见问题(如多线程和序列化问题)及其解决方案,并通过代码示例详细说明了这些内容。希望本文能帮助你在实际开发中更好地应用单例模式,提高代码质量和可维护性。
585 1
|
设计模式 Java
设计模式--适配器模式 Adapter Pattern
这篇文章介绍了适配器模式,包括其基本介绍、工作原理以及类适配器模式、对象适配器模式和接口适配器模式三种实现方式。
|
设计模式 算法 C#
C#设计模式之策略模式
C#设计模式之策略模式
227 19
|
设计模式 C# 开发者
C#设计模式入门实战教程
C#设计模式入门实战教程
175 3
|
设计模式 安全 程序员
C#设计模式之单例模式
C#设计模式之单例模式
183 3
|
设计模式 安全 Java
【设计模式】JAVA Design Patterns——Curiously Recurring Template Pattern(奇异递归模板模式)
该文介绍了一种C++的编程技巧——奇异递归模板模式(CRTP),旨在让派生组件能继承基本组件的特定功能。通过示例展示了如何创建一个`Fighter`接口和`MmaFighter`类,其中`MmaFighter`及其子类如`MmaBantamweightFighter`和`MmaHeavyweightFighter`强制类型安全,确保相同重量级的拳手之间才能进行比赛。这种设计避免了不同重量级拳手间的错误匹配,编译时会报错。CRTP适用于处理类型冲突、参数化类方法和限制方法只对相同类型实例生效的情况。
【设计模式】JAVA Design Patterns——Curiously Recurring Template Pattern(奇异递归模板模式)