代码改变世界

C#1~3 从委托看C#的进化(深入解析c#读书笔记)

2011-02-08 14:08  穆容  阅读(318)  评论(0编辑  收藏  举报

在c#1中,为了让委托做事,需要满足四个条件

1. 声明委托类型

delegate void StringProcessor(string input)

2. 必须有一个方法包含了要执行的代码(并且与上一条中的签名匹配)

void PrintString(string x)

{…}

3. 必须创建一个委托实例

StringProcessor proc1;

proc1 = new StringProcessor(PrintString)

4. 必须调用委托实例

proc1 (”Hello“)

 

到了c#2中的呢,委托变成了这个样子:

首先,在c#2中引入了一中隐式转换:

c#2支持从方法组到一个兼容委托类型的隐式转换,所谓方法组,其实就是一个方法名

如在1.0中的:proc1 = new StringProcessor(PrintString)

到了2.0中就变成了:proc1 = PrintString

隐式转换会将一个方法组转换为具有兼容签名的任意委托类型

这是其一,其二在c#2.0中,还引入了匿名方法的概念

匿名方法允许你指定一个内联委托实例的操作,座位创建委托的实例表达式的一部分。形如

Proc1 = delegate(string input)

{…}

书中的例子更能说明问题,形如:

Action<string> printReverse = delegate(string text)

{

char[] c = text.ToCharArray();

Array.Reverse(c);

}

 

在C#3中,委托被Lambda表达式所代替,形如

Func<string,int> returnLength;

returnLength = text=>text.length;

此外,我们上面的例子可以改写为:

Proc1 = text =>{Console.Write(text);}

 

明白了这个升级关系后,今后再在LINQ中遇到FUNC<xxx>之类的东西,就不会头大了