哇卡卡。怎么老是觉得贞子在我的余光中? 首先补充一点课外知识: 1、所谓匿名函数,就是没有名字的函数。(囧)。那没有名字,我怎么去调用它呢?答案就是,必须要一个有名字的委托来间接调用它。(更囧了。为了不给函数取名字,反而要对委托取名字)。 2、所谓委托,简单说就是指向函数的指针,不要想多了。而且而且,在C#中,同一类型的N个函数(拥有相同类型和返回类型)是可以挂在一个委托下进行链式反应滴。所以,委托,不仅仅是个指针。他是功能无比NB的指针。自带了一个arraylist保存函数链。 今天,我们就用匿名函数来实现C语言中的Printf。 版本一:一般来说,我们可能会这么写。(这不是自欺欺人吗?)
static void Printf(string s)
{
Console.WrintLine(s);
}
版本二:我们当然也可以使用匿名函数
static void Main(string[] args)
{
PrintDel Printff = delegate(string s)
{
Console.WriteLine(s);
};
Printff("hello world");
}
delegate void PrintDel(string s);
注意,函数是没有名字的,委托名叫PrintDel,它的一个实例(也就是一个指针,名叫Printff)。我们通过调用PrintDel委托的一个实例Printff执行相关代码。Printff已经被绑定上了可执行的代码。它指向这一个匿名函数。 版本三:下面介绍我们的lambda 函数。几乎所有使用匿名委托的地方,都能使用此神器进行简写。
Action<string> Printf = (x) =>
{
Console.WriteLine(x);
};
Printf("hello world");
系统默认封装的方法Action(返回类型是void的委托,需要返回其它类型可以使用Func),传入参数的值是string类型。委托名字叫Printf。传入的参数名称是 x 。执行的代码在大括号间。 下面背lambda公式 : Action<参数类型> 委托实例名 = (参数名,参数名)=>{ 执行代码; } 调用: 委托实例名(参数) 如果需要使用返回类型,可以使用Func<传入参数类型,...,返回类型>。比如计算两个数的加法。我们可以这么玩。此委托传入值是两个int,返回一个int类型的值。委托的代码在括号间。
Func<int, int, int> Add = (x, y) =>
{
return x + y;
};
Console.WriteLine(Add(2, 3));