zl程序教程

您现在的位置是:首页 >  后端

当前栏目

C#基础之泛型委托实例教程

c#基础 实例教程 委托 之泛
2023-06-13 09:15:45 时间

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

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

就拿C#里最常见的委托EventHandler打比方。在.NET2.0以前,也就是泛型出现以前,普通的事件处理函数都由EventHandler定义,如下:

publicdelegatevoidEventHandler(objectsender,EventArgse);

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

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

[Serializable]
publicdelegatevoidEventHandler<TEventArgs>(objectsender,TEventArgse)whereTEventArgs:EventArgs;

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

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

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

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

classIntEventArgs:System.EventArgs
{
publicintIntValue{get;set;}
publicIntEventArgs(){}
publicIntEventArgs(intvalue)
{this.IntValue=value;}
}

classStringEventArgs:System.EventArgs
{
publicstringStringValue{get;set;}
publicStringEventArgs(){}
publicStringEventArgs(stringvalue)
{this.StringValue=value;}
}

classProgram
{
staticvoidPrintInt(objectsender,IntEventArgse)
{
Console.WriteLine(e.IntValue);
}

staticvoidPrintString(objectsender,StringEventArgse)
{
Console.WriteLine(e.StringValue);
}

staticvoidMain(string[]args)
{
EventHandler<IntEventArgs>ihandler=newEventHandler<IntEventArgs>(PrintInt);
EventHandler<StringEventArgs>shandler=newEventHandler<StringEventArgs>(PrintString);

ihandler(null,newIntEventArgs(100));
shandler(null,newStringEventArgs("HelloWorld"));
}
}

有关泛型的具体特性与其在面向对象思想中的应用,本站有相关文章做了详细解读,感兴趣的读者可以查阅参考一下。