观察者(Observer)模式 * 委托事件
观察者(Observer)模式:定义了一种一对多的依赖关系。让多个观察者对象同时监听某一个主题对象。
这个主题对象发生变化时会通知所有观察者对象,使他们字段更新自己
/*
* 抽象主题(Subject)角色:主题角色把所有对观察考对象的引用保存在一个聚集里,每个主题都可以有任何数量的观察者。
抽象主题提供一个接口,可以增加和删除观察者对象,主题角色又叫做抽象被观察者(Observable)角色,一般用一个抽象类或者一个接口实现。
* 抽象观察者(Observer)角色:为所有的具体观察者定义一个接口,在得到主题的通知时更新自己。这个接口叫做更新接口。
抽象观察者角色一般用一个抽象类或者一个接口实现。在这个示意性的实现中,更新接口只包含一个方法(即Update()方法),这个方法叫做更新方法。
* 具体主题(ConcreteSubject)角色:将有关状态存入具体现察者对象;
在具体主题的内部状态改变时,给所有登记过的观察者发出通知。具体主题角色又叫做具体被观察者角色(Concrete Observable)。
具体主题角色通常用一个具体子类实现。
* 具体观察者(ConcreteObserver)角色:存储与主题的状态自恰的状态。具体现察者角色实现抽象观察者角色所要求的更新接口,
以便使本身的状态与主题的状态相协调。如果需要,具体现察者角色可以保存一个指向具体主题对象的引用。
具体观察者角色通常用一个具体子类实现。
*/
Console.WriteLine("\n =========实例2========== \n");
Secretary1 tongzzhe = new Secretary1();
StockObserver stock = new StockObserver("张某某", tongzzhe);
NBAObserver nba = new NBAObserver("王某某", tongzzhe);
tongzzhe.Attach(stock);
tongzzhe.Attach(nba);
tongzzhe.SubjectText = "老板回来了";
tongzzhe.Notify();
Console.ReadLine();
//抽象通知者 -- 接口
public interface Subject1
{
//增加
void Attach(Observer1 observer1);
void Remove(Observer1 observer1);
void Notify();
string SubjectText
{ get; set; }
}
//通知者
public class Secretary1 : Subject1
{
//通知列表
private List<Observer1> observers = new List<Observer1>();
//增加
public void Attach(Observer1 observer1)
{
observers.Add(observer1);
}
public void Remove(Observer1 observer1)
{
observers.Remove(observer1);
}
//通知
public void Notify()
{
foreach (Observer1 o in observers)
o.Update();
}
public string SubjectText
{ get; set; }
}
//抽象观察者
public abstract class Observer1
{
protected string name;
protected Subject1 sub;
public Observer1(string name, Subject1 sub)
{
this.name = name;
this.sub = sub;
}
public abstract void Update();
}
//看股票同事
public class StockObserver : Observer1
{
public StockObserver(string name, Subject1 sub)
: base(name, sub)
{ }
public override void Update()
{
Console.WriteLine("{0},{1} 关闭股票,继续工作。", sub.SubjectText,name);
}
}
//看NBA同事
public class NBAObserver : Observer1
{
public NBAObserver(string name, Subject1 sub)
: base(name, sub)
{ }
public override void Update()
{
Console.WriteLine("{0},{1} 关闭NBA,继续工作。", sub.SubjectText, name);
}
}
观察者模式的演变。 具体观察者 也就是StockObserver 其实就是为 事件提供方法。
Console.WriteLine("\n =========实例2========== \n");
Secretary1 tongzzhe = new Secretary1();
StockObserver stock = new StockObserver("张某某", tongzzhe);
NBAObserver nba = new NBAObserver("王某某", tongzzhe);
tongzzhe.Attach(stock.Update);
tongzzhe.Attach(nba.Update);
tongzzhe.SubjectText = "老板回来了";
tongzzhe.Notify();
//抽象通知者 -- 接口
public interface Subject1
{
void Notify();
string SubjectText
{ get; set; }
}
public delegate void EventHandler();
//通知者
public class Secretary1 : Subject1
{
// 声明事件;
public event EventHandler eventHandler;
//通知列表
private List<Observer1> observers = new List<Observer1>();
//增加
public void Attach(EventHandler observer1)
{
eventHandler += observer1;
}
public void Remove(EventHandler observer1)
{
eventHandler -= observer1;
}
//通知
public void Notify()
{
if (eventHandler != null)
eventHandler();
}
public string SubjectText
{ get; set; }
}
//抽象观察者
public abstract class Observer1
{
protected string name;
protected Subject1 sub;
public Observer1(string name, Subject1 sub)
{
this.name = name;
this.sub = sub;
}
public abstract void Update();
}
//看股票同事
public class StockObserver : Observer1
{
public StockObserver(string name, Subject1 sub)
: base(name, sub)
{ }
public override void Update()
{
Console.WriteLine("{0},{1} 关闭股票,继续工作。", sub.SubjectText,name);
}
}
//看NBA同事
public class NBAObserver : Observer1
{
public NBAObserver(string name, Subject1 sub)
: base(name, sub)
{ }
public override void Update()
{
Console.WriteLine("{0},{1} 关闭NBA,继续工作。", sub.SubjectText, name);
}
}
观察者(Observer)模式 * 委托事件的更多相关文章
- Java 实现观察者(Observer)模式
1. Java自带的实现 类图 /** * 观察目标 继承自 java.util.Observable * @author stone * */ public class UpdateObservab ...
- 设计模式C++描述----04.观察者(Observer)模式
一. 概述 Observer 模式要解决的问题为:建立一个一(Subject)对多(Observer)的依赖关系,并且做到当“一”变化的时候,依赖这个“一”的多也能够同步改变. Sbuject 相当于 ...
- 观察者(Observer)模式
观察者模式又叫做发布-订阅模式(Publish.Subscribe)模式.模型-视图模式(Model/View)模式.源-监听器模式(Source/Listener)模式或从属者(Dependents ...
- Java设计模式之从[星际争霸的兵种升级]分析观察者(Observer)模式
观察者模式定义对象的一种一对多的依赖关系.当一个对象的状态发生改变时.全部依赖于它的对象都会得到通知并被自己主动更新. 一个简单的样例是.在星际争霸的虫族中有一个0基础单位叫做跳狗(Zergling) ...
- 面向对象设计模式——观察者(OBSERVER)模式
定义 定义对象间的一种一对多的依赖关系,当一个对象的状态发生改变时,所有依赖于它的对象都得到通知并被自动更新. Observer模式描述了如何建立这种关系.这一模式中的关键对象是目标(subject ...
- 设计模式之观察者(OBSERVER)模式
定义 定义对象间的一种一对多的依赖关系,当一个对象的状态发生改变时,所有依赖于它的对象都得到通知并被自动更新. Observer模式描述了如何建立这种关系.这一模式中的关键对象是目标(subject ...
- java观察者(Observer)模式
观察者模式: 试想,在电子商务网站上,一个用户看中了一件一份,但是当时衣服的价格太贵,你需要将衣服收藏,以便等衣服降价时自动通知该用户.这里就是典型的观察模式的例子. 1.观察者模式的 ...
- Head First 设计模式 —— 02. 观察者 (Observer) 模式
思考题 在我们的一个实现中,下列哪种说法正确?(多选) P42 public class WeatherDate { // 实例变量声明 public void measurementsChanged ...
- 《Head First 设计模式》ch.2 观察者(Observer)模式
观察者模式 定义了对象之间一对多以来,这样一来,当一个对象改变状态时,它所有的依赖者都会收到通知并自动更新 设计原则-松耦合 松耦合将对象之间的互相依赖降到了最低——只要他们之间的接口仍被遵守 观察者 ...
随机推荐
- 字符串(二)(PHP)
1.大段文本在PHP中应该如果表示? 答: <?php $str = <<<aaa hello word; fjasdflj fjslad aaa;date_sub() aaa ...
- Backit轻松为您的网站创建备份
随着日益复杂,备份数据,已成为一个经验法则,为维护数据库和重要的企业信息化的大公司和企业.在一个不幸的灾难的情况下,很多企业无法恢复他们的数据,这进一步增加了在他们对所有盈利和亏损的同时,作为他们的电 ...
- Debian上启用Apache2服务
在Debian上启用Apache2的方法如下: sudo apt-get update sudo apt-get install -y apache2 sudo service apache2 sta ...
- (转)C# Socket异步通信
本文转载自:http://www.cnblogs.com/llllll/archive/2009/05/13/1455703.html 服务器端 TCPServer 1.使用的通讯通道:socket ...
- 字节序(byte order)和位序(bit order)
字节序(byte order)和位序(bit order) 在网络编程中经常会提到网络字节序和主机序,也就是说当一个对象由多个字节组成的时候需要注意对象的多个字节在内存中的顺序. 以前我也基本只了 ...
- 1097 Deduplication on a Linked List
题意: 给出一个链表,删除绝对值相同的结点,对于每个绝对值为K的结点,只保留第一次出现的那个.把被移除的结点组成一个新链表,输出删除去重后的链表和新链表. 思路:考察链表的“删除”操作,不难. 代码: ...
- fullCalendar动态获取数据
fullCalendar http://fullcalendar.io/docs/event_data/events_function $('#calendar').fullCalendar({ he ...
- 用python40行代码编写的计算器
效果图 代码 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 ...
- Iterator(迭代器)的一般用法 (转)
迭代器(Iterator) 迭代器是一种设计模式,它是一个对象,它可以遍历并选择序列中的对象,而开发人员不需要了解该序列的底层结构.迭代器通常被称为“轻量级”对象,因为创建它的代价小. Java中的I ...
- cxf和axis2使用有感
CXF框架 个人不喜欢使用wsimport工具: 1.考虑到远端的服务接口发生变化,本地的接口还需要重新同步下 2.项目中无端多了些冗余的代码 这样我们选择cxf的动态调用接口吧,使用DynamicC ...