C#中的委托事件机制是这种语言的一大亮点,以一种更加安全和高效的方式可以实现类似C语言中的函数指针,Qt中的信号槽机制和委托事件机制在实际运用中颇为相似,但是,C#使用上更加方便。下面,我先贴个图来展示一个事件机制的原理:

wKiom1S9v22zuZEDAADWSMO5SeA502.jpg

        上述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);                   
            }

        }        
    }
}