就拿C#里最常见的委托EventHandler打比方

时间:2021-10-12 08:44:06

本文实例讲述了C#中泛型委托的用法,并以示例形式较为详细的进行了用法分析。分享给大家供大家参考之用。具体如下:

首先,,泛型委托是委托的一种特殊形式,虽然觉得看上去对照怪异,其实在使用的时候跟委托差不久不多,不过泛型委托更具有类型通用性。

就拿C#里最常见的委托EventHandler打比喻。在.NET 2.0以前,也就是泛型呈现以前,普通的事件措置惩罚惩罚函数都由EventHandler界说,如下:

public delegate void EventHandler(object sender, EventArgs e);

EventHandler指代了这样一类函数,这些函数没有返回值,并且有两个参数,第一个参数是object类型,而第二个参数是EventArgs类型。

而.NET 2.0及其以后的版本,由于泛型的引入,所以一些内建(Built-in)的类、接口、委托都有了各自的泛型版本。EventHandler也不例外,它有了本身的泛型版本:EventHandler<T>,它的界说如下:

[Serializable] public delegate void EventHandler<TEventArgs>(object sender, TEventArgs e) where TEventArgs: EventArgs;

您应该可以发明,第二个参数的类型由EventArgs酿成了TEventArgs,而TEventArgs具体是什么,则由挪用方决定。假设IntEventArgs和StringEventArgs都担任于System.EventArgs,那么:

1.EventHandler<IntEventArgs>指代这样一类函数:这些函数没有返回值,有两个参数,第一个参数是object类型,第二个参数是IntEventArgs类型

2.EventHandler<StringEventArgs>指代这样一类函数:这些函数没有返回值,有两个参数,第一个参数是object类型,第二个参数是StringEventArgs类型

其实EventHandler<IntEventArgs>和EventHandler<StringEventArgs>是两个完全差此外委托,它们所指代的函数都分袂有着差此外签名形式。请参见下面的示例:

class IntEventArgs : System.EventArgs { public int IntValue { get; set; } public IntEventArgs() { } public IntEventArgs(int value) { this.IntValue = value; } } class StringEventArgs : System.EventArgs { public string StringValue { get; set; } public StringEventArgs() { } public StringEventArgs(string value) { this.StringValue = value; } } class Program { static void PrintInt(object sender, IntEventArgs e) { Console.WriteLine(e.IntValue); } static void PrintString(object sender, StringEventArgs e) { Console.WriteLine(e.StringValue); } static void Main(string[] args) { EventHandler<IntEventArgs> ihandler = new EventHandler<IntEventArgs>(PrintInt); EventHandler<StringEventArgs> shandler = new EventHandler<StringEventArgs>(PrintString); ihandler(null, new IntEventArgs(100)); shandler(null, new StringEventArgs("Hello World")); } }