代码如下: ProcessWordDelegate p = delegate(string s) { Console.

时间:2021-07-14 07:53:44

委托是c#中类型安适的,可以订阅一个或多个具有不异签名要领的函数指针

声明委托的方法:delegate 返回值类型 委托类型名(参数)

好比:


代码如下:


delegate void StringProcess(string s);

注意:这里的除了前面的delegate,剩下部分和声明一个函数一样,但是StringProcess不是函数名,而是委托类型名

声明的委托是一种类型,就像int、Person一样,,如果要用的话还要声明委托类型的变量,声明委托类型变量的方法:StringProcess f1;

将委托类型变量指向函数 StringProcess sp = new StringProcess(SayHello),这样就可以像挪用普通函数一样把sp当成函数用了。委托可以看做是函数的指针。整数可以用整数变量指向它,东西可以用东西变量指向它,函数也可以用委托变量指向它。和直接挪用函数的区别:用委托就可以指向任意的函数,哪怕是之前没界说的都可以,而不使用受限于那几种。

将委托类型变量指向函数还可以简化成StringProcess sp = SayHello,编译器帮我们进行了new。但是不能sp=PrintIt(),因为这样就成了函数挪用。


代码如下:


using System;

using System.Collections.Generic;

using System.Linq;

using System.Text;

using System.Threading.Tasks;

namespace Wolfy.DelegateTest

{

class Program

{

delegate void StringProcess(string s);

static void Main(string[] args)

{

string s = “HI,I AM WOLFY”;

string s2 = “HOW DO YOU DO?”;

//界说委托变量p

StringProcess p = new StringProcess(ToLower);

//简化方法

StringProcess p2 = ToLower;

p(s);

p2(s2);

Console.Read();

}

static void ToLower(string s)

{

Console.WriteLine(s.ToLower());

}

}

}

功效:

代码如下: ProcessWordDelegate p = delegate(string s) { Console.


代码如下:


StringProcess p2 = ToLower;

这种简化方法,编译器到底为我们做了什么?可以通过反编译工具看一下:

代码如下: ProcessWordDelegate p = delegate(string s) { Console.

可以见编译器帮咱们new了一个。

返回类型和签名指定了委托的接受要领的形式:也就是你的委托是什么样式的,指向的要领也要是什么样式的,好比这里返回类型为void 参数是string类型的。

代码如下: ProcessWordDelegate p = delegate(string s) { Console.

代码如下: ProcessWordDelegate p = delegate(string s) { Console.


匿名要领

使用Delegate的时候很多时候没须要使用一个普通的要领,因为这个要领只有这个Delegate会用,并且只用一次,这时候使用匿名要领最合适。

匿名要领就是没有名字的要领。3就是没有名字的int东西。3+5就是两个匿名int东西的相加,允许匿名东西,就允许匿名要领。


代码如下:


ProcessWordDelegate p = delegate(string s)

{

Console.WriteLine(s);