行为型-观察者模式、基于事件的观察者

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
//行为型-观察者模式、基于事件的观察者
namespace Chap2_2
{
public class Observer
{
Employee emp = EmployeeFactory.CreateEmployee("Alfred_Xu", "南京、成都", EmployeeFactory.addressFactory);
public void testObserver()
{
emp.EmployeeChangenameEvent += Employee.employee_EmployeeChangeNameEvent;//订阅事件,定义事件触发后,由谁来做什么
emp.ChangeName("Alfred.Xu");
Console.ReadKey();
}

public void testObserver2()
{

emp.EmployeeChangenameEvent += empChangeName;//订阅事件
emp.ChangeName("Alfred.Xu");
Console.ReadKey();
}

public void empChangeName(string name)
{
Console.WriteLine("修改后的名称;" + name);
}
public void show()
{
Console.WriteLine(string.Format("员工名:{0}", emp.Name));
Console.WriteLine(string.Format("户籍地:{0}", emp.AddressCollection.Address1));
Console.WriteLine(string.Format("工作地:{0}", emp.AddressCollection.Address2));
}
}

public partial class Employee
{
//定义委托
public delegate void EmployeeChangedName(string ChangedName);
//创建委托对象
private EmployeeChangedName employeeChangedName;
//具体的事件
public event EmployeeChangedName EmployeeChangenameEvent
{
add { employeeChangedName += value; }
remove { if (employeeChangedName != null) { employeeChangedName -= value; } }
}
//该方法执行时,触发事件
public void ChangeName(string name)
{
this.Name = name;
this.employeeChangedName(name);//事件只有在对象内部才能触发
}
//事件的具体执行,方法与上面的委托一致
static public void employee_EmployeeChangeNameEvent(string ChangeName)
{
Console.WriteLine("修改后的名称;"+ChangeName);
}
}
}

时间: 2024-10-20 10:40:18

行为型-观察者模式、基于事件的观察者的相关文章

java设计模式--观察者模式和事件监听器模式

文章转载于:http://www.java2000.net/p9452 复习设计模式,看到observer观察者模式,说法是该模式和iterator迭代器模式类似已经被整合进jdk,但是jdk提供了两种接口: 一.java.util.Observer -- 观察者接口 对应: java.util.Observable --受查者根类 二.java.util.EventListener -- 事件监听/处理接口 对应: java.util.EventObject -- 事件(状态)对象根类 研究了

C#委托与事件之观察者Observer设计模式

前言    委托: 委托是一种在对象里保存方法引用的类型,同时也是一种类型安全的函数指针. 或委托可以看成一种表示函数的数据类型,类似函数指针. 事件是特殊的委托 观察者模式:两种角色:(1)Subject, 主题(被监视对象),它往往包含着 Observer 所感兴趣的内容.(2)Observer, 观察者,它观察 Subject. 当 Subject 中的某件事发生的时候(通常是它所感兴趣的内容改变的时候),会被自动告知,而 Observer 则会采取相应的行动(通常为更新自身状态或者显示输

MSDN搬运 之 [基于事件的异步模式]

基于事件的异步模式概述 那些同时执行多项任务.但仍能响应用户交互的应用程序通常需要实施一种使用多线程的设计方案.System.Threading 命名空间提供了创建高性能多线程应用程序所必需的所有工具,但要想有效地使用这些工具,需要有丰富的使用多线程软件工程的经验.对于相对简单的多线程应用程序,BackgroundWorker 组件提供了一个简单的解决方案.对于更复杂的异步应用程序,请考虑实现一个符合基于事件的异步模式的类. 基于事件的异步模式具有多线程应用程序的优点,同时隐匿了多线程设计中固有

C#中的异步调用及异步设计模式(三)——基于事件的异步模式

四.基于事件的异步模式(设计层面) 基于事件的C#异步编程模式是比IAsyncResult模式更高级的一种异步编程模式,也被用在更多的场合.该异步模式具有以下优点: ·                  “在后台”执行耗时任务(例如下载和数据库操作),但不会中断您的应用程序. ·                  同时执行多个操作,每个操作完成时都会接到通知(在通知中可以区分是完成了哪个操作). ·                  等待资源变得可用,但不会停止(“挂起”)您的应用程序. ·  

基于事件的异步模式——BackgroundWorker

实现异步处理的方法很多,经常用的有基于委托的方式,今天记录的是基于事件的异步模式.利用BackgroundWorker组件可以很轻松的实现异步处理,并且该组件还支持事件的取消.进度报告等功能.本文以计算两个数X.Y的和为例. 程序界面如下图,其中三个文本框分别为两个加数和处理结果,两个按钮为计算和取消,按钮下方为进度条. 引入BackgroundWorker组件,为DoWork.ProgressChanged.RunWorkerCompleted三个事件指定方法.将WorkerReportsPr

基于事件的 NIO 多线程服务器--转载

JDK1.4 的 NIO 有效解决了原有流式 IO 存在的线程开销的问题,在 NIO 中使用多线程,主要目的已不是为了应对每个客户端请求而分配独立的服务线程,而是通过多线程充分使用用多个 CPU 的处理能力和处理中的等待时间,达到提高服务能力的目的. 多线程的引入,容易为本来就略显复杂的 NIO 代码进一步降低可读性和可维护性.引入良好的设计模型,将不仅带来高性能.高可靠的代码,也将带来一个惬意的开发过程. 线程模型 NIO 的选择器采用了多路复用(Multiplexing)技术,可在一个选择器

【ALB学习笔记】基于事件触发方式的串行通信接口数据接收案例

基于事件触发方式的串行通信接口数据接收案例 广东职业技术学院  欧浩源 1.案例背景 之前写过一篇<基于多线程方式的串行通信接口数据接收案例>的博文,讨论了采用轮询方式接收串口数据的情况.经过使用了多线程来处理,而然轮询的办法比较还是比较笨拙的.我们在实际的项目开发中,更加常用的是基于事件触发的方式,这个方式不但好用,而且灵活,只是使用起来需要更多的一点专业知识.在本博文中,就"传感器模块每隔1秒钟向上位机传送4字节的电压数据帧"的项目,对该方法的设计进行详细的讲述.  

基于事件的异步模式(EAP)

什么是EAP异步编程模式 EAP基于事件的异步模式是.net 2.0提出来的,实现了基于事件的异步模式的类将具有一个或者多个以Async为后缀的方法和对应的Completed事件,并且这些类都支持异步方法的取消.进度报告和报告结果.然而.net中并不是所有的类都支持EAP,总结起来有以下17个类支持EAP异步. System.Object的派生类型: System.Activies.WorkflowInvoke System.Deployment.Application.ApplicationD

【温故知新】C#基于事件的异步模式(EAP)

在开发winform和调用asp.net的web service引用的时候,会出现许多命名为 MethodNameAsync 的方法. 例如: winform的按钮点击 this.button1.Click += new System.EventHandler(this.button1_Click); private void button1_Click(object sender, EventArgs e) { //dosomething } 这就是基于事件的异步编程模式,它实现了不影响主线程