C#事件也可以异步触发
在做项⽬时,通过事件机制来触发⼀些动作。本能的过分相信事件机制的并发处理能⼒,结果发现程序在事件拥堵的时候会假死。google 了下,发现事件也可以异步,整理如下:
如何实现异步事件调⽤呢?事件其实是⼀种MulticastDelegate(多播委托)。⽽MulticastDelegate类提供了⼀个GetInvocationList⽅法,该⽅法返回此多播委托的委托调⽤数组。利⽤该⽅法就能实现我们的异步事件调⽤功能。
代码:
using System;
using System.Threading;
using System.Runtime.Remoting.Messaging;
namespace ProcessTest
{
class Program
{
//定义⼀个事件
public static event EventHandler<EventArgs> OnEvent;
//⽅法1
static void Method1(object sender, EventArgs e)
{
//显⽰执⾏该⽅法的线程ID
Console.WriteLine("调⽤Method1的线程ID为:{0}", Thread.CurrentThread.ManagedThreadId);
Thread.Sleep(1000);
}
/
/⽅法2
static void Method2(object sender, EventArgs e)
{
Console.WriteLine("调⽤Method2的线程ID为:{0}", Thread.CurrentThread.ManagedThreadId);
Thread.Sleep(1000);
}
static void Main(string[] args)
{
//显⽰主线程ID
System.Console.WriteLine("主线程ID为:{0}", Thread.CurrentThread.ManagedThreadId);            //将Method1和Method2注册到事件中
OnEvent += new EventHandler<EventArgs>(Method1);
OnEvent += new EventHandler<EventArgs>(Method2);
//下⾯的代码实现事件的异步调⽤
//获取事件中的多路委托列表
Delegate[] delegAry = OnEvent.GetInvocationList();
gary事件是什么//遍历委托列表
foreach (EventHandler<EventArgs> deleg in delegAry)
{
//异步调⽤委托
deleg.BeginInvoke(null, EventArgs.Empty, null, null);
}
System.Console.ReadKey();
}
}
}