.NET设计模式(19):观察者模式(Observer Pattern)
2011-09-21 22:53
435 查看
概述
在软件构建过程中,我们需要为某些对象建立一种“通知依赖关系” ——一个对象(目标对象)的状态发生改变,所有的依赖对象(观察者对象)都将得到通知。如果这样的依赖关系过于紧密,将使软件不能很好地抵御变化。使用面向对象技术,可以将这种依赖关系弱化,并形成一种稳定的依赖关系。从而实现软件体系结构的松耦合。
意图
定义对象间的一种一对多的依赖关系,当一个对象的状态发生改变时, 所有依赖于它的对象都得到通知并被自动更新。[GOF 《设计模式》]
结构图
public class Microsoft
public class Investor
简单的客户端实现:
class Program
public class Mobile
这时候对应的Microsoft的类就应该改变为如下代码,在Microsot类中增加Mobile,同时修改Update()方法使其可以通知到移动设备:
public class Microsoft
public interface IObserver
public class Investor : IObserver
public class Microsoft
public class Microsoft
此时客户端的调用代码:
class Program
public abstract class Stock
public class Microsoft : Stock
public interface IObserver
public class Investor : IObserver
客户端程序代码如下:
class Program
public abstract class Stock
public class Microsoft : Stock
public interface IObserver
public class Investor : IObserver
class Program
class Program
public delegate void NotifyEventHandler(object sender);
public class Stock
public class Investor
效果及实现要点
1.使用面向对象的抽象,Observer模式使得我们可以独立地改变目标与观察者,从而使二者之间的依赖关系达到松耦合。
2.目标发送通知时,无需指定观察者,通知(可以携带通知信息作为参数)会自动传播。观察者自己决定是否需要订阅通知。目标对象对此一无所知。
3.在C#中的Event。委托充当了抽象的Observer接口,而提供事件的对象充当了目标对象,委托是比抽象Observer接口更为松耦合的设计。
适用性
1.当一个抽象模型有两个方面, 其中一个方面依赖于另一方面。将这二者封装在独立的对象中以使它们可以各自独立地改变和复用。
2.当对一个对象的改变需要同时改变其它对象, 而不知道具体有多少对象有待改变。
3.当一个对象必须通知其它对象,而它又不能假定其它对象是谁。换言之, 你不希望这些对象是紧密耦合的。
总结
通过Observer模式,把一对多对象之间的通知依赖关系的变得更为松散,大大地提高了程序的可维护性和可扩展性,也很好的符合了开放-封闭原则。
在软件构建过程中,我们需要为某些对象建立一种“通知依赖关系” ——一个对象(目标对象)的状态发生改变,所有的依赖对象(观察者对象)都将得到通知。如果这样的依赖关系过于紧密,将使软件不能很好地抵御变化。使用面向对象技术,可以将这种依赖关系弱化,并形成一种稳定的依赖关系。从而实现软件体系结构的松耦合。
意图
定义对象间的一种一对多的依赖关系,当一个对象的状态发生改变时, 所有依赖于它的对象都得到通知并被自动更新。[GOF 《设计模式》]
结构图
public class Microsoft
public class Investor
简单的客户端实现:
class Program
public class Mobile
这时候对应的Microsoft的类就应该改变为如下代码,在Microsot类中增加Mobile,同时修改Update()方法使其可以通知到移动设备:
public class Microsoft
public interface IObserver
public class Investor : IObserver
public class Microsoft
public class Microsoft
此时客户端的调用代码:
class Program
public abstract class Stock
public class Microsoft : Stock
public interface IObserver
public class Investor : IObserver
客户端程序代码如下:
class Program
public abstract class Stock
public class Microsoft : Stock
public interface IObserver
public class Investor : IObserver
class Program
class Program
public delegate void NotifyEventHandler(object sender);
public class Stock
public class Investor
效果及实现要点
1.使用面向对象的抽象,Observer模式使得我们可以独立地改变目标与观察者,从而使二者之间的依赖关系达到松耦合。
2.目标发送通知时,无需指定观察者,通知(可以携带通知信息作为参数)会自动传播。观察者自己决定是否需要订阅通知。目标对象对此一无所知。
3.在C#中的Event。委托充当了抽象的Observer接口,而提供事件的对象充当了目标对象,委托是比抽象Observer接口更为松耦合的设计。
适用性
1.当一个抽象模型有两个方面, 其中一个方面依赖于另一方面。将这二者封装在独立的对象中以使它们可以各自独立地改变和复用。
2.当对一个对象的改变需要同时改变其它对象, 而不知道具体有多少对象有待改变。
3.当一个对象必须通知其它对象,而它又不能假定其它对象是谁。换言之, 你不希望这些对象是紧密耦合的。
总结
通过Observer模式,把一对多对象之间的通知依赖关系的变得更为松散,大大地提高了程序的可维护性和可扩展性,也很好的符合了开放-封闭原则。
相关文章推荐
- .NET设计模式(19):观察者模式(Observer Pattern)
- .NET设计模式(19):观察者模式(Observer Pattern)
- .NET设计模式(19):观察者模式(Observer Pattern)
- .NET设计模式(19):观察者模式(Observer Pattern)
- .NET设计模式(19):观察者模式(Observer Pattern)
- .NET设计模式(19):观察者模式(Observer Pattern)(转)
- [设计模式] 19 观察者模式 Observer Pattern
- .NET设计模式:观察者模式(Observer Pattern)
- .NET设计模式:观察者模式(Observer Pattern)
- "围观"设计模式(19)--行为型之观察者模式(Observer Pattern)
- .NET设计模式-观察者模式(Observer Pattern)
- 【转载】.NET设计模式之观察者模式(Observer Pattern)
- 设计模式之二:观察者模式(Observer Pattern)
- 观察者模式(Observer Pattern) .NET设计模式
- 设计模式----行为型模式之观察者模式(Observer Pattern)
- 设计模式(二)The Observer Pattern 观察者模式
- C#设计模式——观察者模式(Observer Pattern)
- 设计模式之观察者模式---Observer Pattern
- Java设计模式之观察者模式(Observer Pattern)
- 设计模式总结之Observer Pattern(观察者模式)