委托是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());
}
}
}
功效:
代码如下:
StringProcess p2 = ToLower;
这种简化方法,编译器到底为我们做了什么?可以通过反编译工具看一下:
可以见编译器帮咱们new了一个。
返回类型和签名指定了委托的接受要领的形式:也就是你的委托是什么样式的,指向的要领也要是什么样式的,好比这里返回类型为void 参数是string类型的。
匿名要领
使用Delegate的时候很多时候没须要使用一个普通的要领,因为这个要领只有这个Delegate会用,并且只用一次,这时候使用匿名要领最合适。
匿名要领就是没有名字的要领。3就是没有名字的int东西。3+5就是两个匿名int东西的相加,允许匿名东西,就允许匿名要领。
代码如下:
ProcessWordDelegate p = delegate(string s)
{
Console.WriteLine(s);