观察者(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)模式 * 委托事件的更多相关文章

  1. Java 实现观察者(Observer)模式

    1. Java自带的实现 类图 /** * 观察目标 继承自 java.util.Observable * @author stone * */ public class UpdateObservab ...

  2. 设计模式C++描述----04.观察者(Observer)模式

    一. 概述 Observer 模式要解决的问题为:建立一个一(Subject)对多(Observer)的依赖关系,并且做到当“一”变化的时候,依赖这个“一”的多也能够同步改变. Sbuject 相当于 ...

  3. 观察者(Observer)模式

    观察者模式又叫做发布-订阅模式(Publish.Subscribe)模式.模型-视图模式(Model/View)模式.源-监听器模式(Source/Listener)模式或从属者(Dependents ...

  4. Java设计模式之从[星际争霸的兵种升级]分析观察者(Observer)模式

    观察者模式定义对象的一种一对多的依赖关系.当一个对象的状态发生改变时.全部依赖于它的对象都会得到通知并被自己主动更新. 一个简单的样例是.在星际争霸的虫族中有一个0基础单位叫做跳狗(Zergling) ...

  5. 面向对象设计模式——观察者(OBSERVER)模式

    定义 定义对象间的一种一对多的依赖关系,当一个对象的状态发生改变时,所有依赖于它的对象都得到通知并被自动更新.  Observer模式描述了如何建立这种关系.这一模式中的关键对象是目标(subject ...

  6. 设计模式之观察者(OBSERVER)模式

    定义 定义对象间的一种一对多的依赖关系,当一个对象的状态发生改变时,所有依赖于它的对象都得到通知并被自动更新.  Observer模式描述了如何建立这种关系.这一模式中的关键对象是目标(subject ...

  7. java观察者(Observer)模式

    观察者模式:     试想,在电子商务网站上,一个用户看中了一件一份,但是当时衣服的价格太贵,你需要将衣服收藏,以便等衣服降价时自动通知该用户.这里就是典型的观察模式的例子.     1.观察者模式的 ...

  8. Head First 设计模式 —— 02. 观察者 (Observer) 模式

    思考题 在我们的一个实现中,下列哪种说法正确?(多选) P42 public class WeatherDate { // 实例变量声明 public void measurementsChanged ...

  9. 《Head First 设计模式》ch.2 观察者(Observer)模式

    观察者模式 定义了对象之间一对多以来,这样一来,当一个对象改变状态时,它所有的依赖者都会收到通知并自动更新 设计原则-松耦合 松耦合将对象之间的互相依赖降到了最低——只要他们之间的接口仍被遵守 观察者 ...

随机推荐

  1. SERDES高速系统(二)

    抖动.容忍度与功耗 前面我提到SERDES的最终性能要用传输速率和传输距离考核.使用眼图可以形象化地衡量SERDES的收发性能,但是更为精确的参数化衡量手段是抖动(Jitter).容忍度(Tolera ...

  2. linux 下SPI通信注意事项(待续)

    一.2台Linux设备之间使用SPI通信 1.标准Linux只支持Master 模式.但是可以在驱动中修改为Slave模式: 2.硬件SPI可能支持Slave模式,也可能不支持.这个要提前确认好: 3 ...

  3. Java-Runoob:Java 运算符

    ylbtech-Java-Runoob:Java 运算符 1.返回顶部 1. Java 运算符 计算机的最基本用途之一就是执行数学运算,作为一门计算机语言,Java也提供了一套丰富的运算符来操纵变量. ...

  4. spring-cloud配置eureka客户端

    spring-cloud配置eureka客户端 eureka用来发现其他程序 需要提前配置eureka服务端,具体看 https://www.cnblogs.com/ye-hcj/p/10292944 ...

  5. maven项目依赖包问题

    问题 maven传递依赖 解决方案   前段时间,开发中遇到一个关于maven依赖包的问题:由于业务需要,支付网关对账代码中的slf4j-api包需要更新,原包为1.5.8版本,需要更新到1.6.4版 ...

  6. Flask之单元测试

    5.2单元测试 为什么要测试? Web程序开发过程一般包括以下几个阶段:[需求分析,设计阶段,实现阶段,测试阶段].其中测试阶段通过人工或自动来运行测试某个系统的功能.目的是检验其是否满足需求,并得出 ...

  7. leetcode893

    class Solution { public: int numSpecialEquivGroups(vector<string>& A) { set<string> ...

  8. Java微信公众平台开发(十)--微信自定义菜单的创建实现

    转自:http://www.cuiyongzhi.com/post/48.html 自定义菜单这个功能在我们普通的编辑模式下是可以直接在后台编辑的,但是一旦我们进入开发模式之后我们的自定义菜单就需要自 ...

  9. entityframework.extended 配置mysql

    entityframework.extended 这个是个很好的扩展,不过由于默认是配置成MSSQL的,今天在github上面 看到一个解决方案,亲测可用,下面贴代码 1.在DbContext 修改默 ...

  10. SQL提取数据库表名,字段名等信息

    -------提取数据库所有表的表名.字段名 -------在SQLserver 2000中测试 --查询所有用户表所有字段的特征 SELECT D.Name as TableName, A.colo ...