C#中的委托事件机制是这种语言的一大亮点,以一种更加安全和高效的方式可以实现类似C语言中的函数指针,Qt中的信号槽机制和委托事件机制在实际运用中颇为相似,但是,C#使用上更加方便。下面,我先贴个图来展示一个事件机制的原理:
湄潭网站建设公司创新互联,湄潭网站设计制作,有大型网站制作公司丰富经验。已为湄潭成百上千提供企业网站建设服务。企业网站搭建\外贸网站建设要多少钱,请找那个售后服务好的湄潭做网站的公司定做!
上述Publisher类的作用就是定义委托、定义事件以及定义触发事件的方法;
Subscriber类的作用注册事件,并且定义具体的事件处理方法。(好像Subscriber类不需要注册事件,注册事件是在运行的模块进行)
这种思想本人以为就是:还没想好怎么做就先搭个框架(写个函数声明),以后那些客户谁想具体怎么做,以后他自己想办法去,我们只把函数签名声明好就够了,免得客户对我们细致的定义不满意。
【上图我感觉解释事件还是有点儿不好理解,我认为理解事件其实就是通过注册事件将事件和事件处理函数联系起来,当事件发生时,我们将我们需要的事件处理函数注册到该事件中,使得我们满意的处理过程发生。】
举个例子(例子是借鉴别人的博文 《C# 事件机制》)
using System; using System.Collections.Generic; using System.Text; using System.Threading; namespace Delegate_And_Event { public delegate void SalaryComputeEventHander(object sender, MyEventArgs e); public class Employee { public event SalaryComputeEventHander SalaryCompute; public virtual void OnSalaryCompute(MyEventArgs e) //触发事件的函数 { if(SalaryCompute != null) { SalaryCompute(this,e); } } } public class MyEventArgs : EventArgs { public readonly double _salary; public MyEventArgs(double salary) { this._salary = salary; } } public class HumanResource { //具体的事件处理函数 public void SalaryHandler(object sender, MyEventArgs e) { Console.Write("Salary is {0}",e._salary); } } class Program { static void Main(string[] args) { Employee ep = new Employee (); HumanResource hr = new HumanResource (); MyEventArgs e = new MyEventArgs (20000.5); ep.SalaryCompute += new SalaryComputeEventHander(hr.SalaryHandler); //将具 体事件处理函数注册到事件中 while (true) { Thread.Sleep(1000); ep.OnSalaryCompute(e); } } } }