说说设计模式~观察者模式(Observer)

时间:2023-03-09 04:58:06
说说设计模式~观察者模式(Observer)

返回目录

观察者模式,也叫发布/订阅模式(publish/subscribe),监视器模式等。在此种模式中,一个目标物件管理所有相依于它的观察者物件,并且在它本身的状态改变时主动发出通知。这通常透过呼叫各观察者所提供的方法来实现。。

何时能用到它?

此种模式通常被用来实现事件处理系统,例如,当一个数据仓储操作中,它的添加功能可能会有一个功能,当添加被触发时,所以订阅了这个添加事件需求的代码 块,都会被触发执行,在这个过程中,数据仓储的添加操作就是被观察者,而所以的订阅者就是它的观察者,发被观察者在某种情况被发起后,所以观察者的代码段 都将被执行。

而对于一个发邮件的功能来说,所有订阅了此功能的模块,只要系统到某个时间点,发邮件的事件就是被触发,此时,所有订阅了此功能的代码模块都会被执行,这种场合,我们见到的不少,如很多网站的新闻订阅,优惠订阅等等,都可以用到它。对于底层开发人员来说,你的CURD操作,如果希望在操作出错后,动态记录日志,事实上,也可以使用这个模式来实现,只要在WEB层或者BLL层订阅一下记录日志的事件即可。

观察者模式的结构图

aaarticlea/png;base64,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" alt="" />

观察者模式实现说明

SubjectBase:被观察者的基类,它包括了添加观察者,删除观察者,触发观察者的功能

Subject:其中一个被观察者

IObserver:被观察者对象接口,所以被观察者都要实现它,其中SubjectBase也会接收一个IObserver对象,用来触发所有观察者

Observer1:观察者1

Observer2:观察者2

观察者模式的C#实现

#region 观察者模式
/// <summary>
/// 被观察者基类
/// </summary>
public abstract class SubjectBase
{
private ArrayList _observers = new ArrayList();
public void Add(IObserver o)
{
_observers.Add(o);
}
public void Remove(IObserver o)
{
_observers.Remove(o);
}
public void Notify()
{
foreach (IObserver o in _observers)
{
o.Notify();
}
}
}
/// <summary>
/// 被观察者(委托)
/// </summary>
public class Subject : SubjectBase
{ } /// <summary>
/// 观察者实现接口(事件)
/// </summary>
public interface IObserver
{
void Notify();
}
/// <summary>
/// 观察者1
/// </summary>
public class Observer1 : IObserver
{
public void Notify()
{
Console.WriteLine("观察者1");
}
}
/// <summary>
/// 观察者2
/// </summary>
public class Observer2 : IObserver
{
public void Notify()
{
Console.WriteLine("观察者2");
}
}
#endregion

测试代码

            Subject subject = new Subject();
subject.Add(new Observer1());
subject.Add(new Observer2());
subject.Notify();

结果如图

aaarticlea/png;base64,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" alt="" />

返回目录