一、Lambda表达式的格式:
(参数列表)=>表达式或语句块
Lambda表达式可以有多个参数、一个参数或没有参数。
实例代码如下:
(x,y)=>x*y //多参数,隐式类型=> 表达式
x=>x*5 //单参数, 隐式类型=>表达式
x => { return x * 5; } //单参数,隐式类型=>语句块
(int x) => x * 5 //单参数,显式类型=>表达式
(int x) => { return x * 5; } //单参数,显式类型=>语句块
() => Console.WriteLine() //无参数
上述格式都是Lambda表达式的合法格式,在编写Lambda表达式时,可以忽略参数的类型,因为编译器能够根据上下文直接推断参数的类型。
Lambda表达式的主体可以是表达式也可以是语句块,这样就节约了代码的编写。
二、基于Lambda表达式的委托写法
Func<int, int, int> max = (int a, int b) =>
{
if (a > b)
{
return a;
}
else
{
return b;
}
};
与上文使用delegate定义匿名方法的作用相同,Lambda表达式的作用也是为了定义一个匿名方法。因此,下面使用delegate的代码和上面是等价的:
Func<int, int, int> max = delegate(int a, int b)
{
if (a > b)
{
return a;
}
else
{
return b;
}
};
Lambda表达式的意义便是它可以写的非常简单,例如之前的Lambda表达式可以简写成这样:
Func<int, int, int> max = (a, b) =>
{
if (a > b)
{
return a;
}
else
{
return b;
}
};
由于我们已经注明max的类型是Func<int, int, int>,因此C#编译器可以明确地知道a和b都是int类型,于是我们就可以省下参数之前的类型信息。这个特性叫做“类型推演”,也就是指编译器可以自动知道某些成员的类型2。请不要轻易认为这个小小的改进意义不大,事实上,您会发现Lambda表达式的优势都是由这一点一滴的细节构成的。那么我们再来一次改变:
Func<int, int, int> max = (a, b) => a > b ? a : b;
如果Lambda表达式只包含一个参数的话,则参数列表的括号也可以省略,如下:
Func<int, bool> positive = a => a > 0;
如今的写法是不是非常简单?那么我们来看看,如果是使用delegate关键字来创建的话会成为什么样子:
Func<int, bool> positive = delegate(int a)
{
return a > 0;
};