强大的Lambda
表达式,简洁到你懵逼。我们知道没有Lambda
表达式之前是delegate
匿名表达式。
注意看下下面代码的注释,明了一下整个省略过程。这里还有之前的一篇笔记https://www.cnblogs.com/huvjie/p/15321191.html。可以结合起来一起看一下。
using System;
namespace ConsoleApp1
{
class Program
{
delegate double Mydel(int par); // 委托
static void Main(string[] args)
{
Mydel del = delegate (int x) { return x + 1; }; // 最初的匿名方法形式
// 1。lambad 表达式必须在参数数量,类型,位置上与委托相匹配
Mydel le1 = (int x) => { return x + 1; }; // 完整Lambda 表达式
// 2。表达式不一定需要包含类型(隐式类型),出了 ref 和 out 参数
Mydel le2 = (x) => { return x + 1; }; // 省略类型
// 3。如果只有一个参数,并且是隐式类型,周围的圆括号都可省略;如果没有参数则必须要有圆括号
Mydel le3 = x => { return x + 1; }; // 省略圆括号
// 4。 如果语句块包含一个返回语句,可以将语句块替换成 return 后面的表达式
// 看起来像省略了 return 和 后面的{}对和分号
Mydel le4 = x => x + 1; // 最简,看起来像 le4 = x + 1;
Console.WriteLine("{0}", del(100));
Console.WriteLine("{0}", le1(100));
Console.WriteLine("{0}", le2(100));
Console.WriteLine("{0}", le3(100));
Console.WriteLine("{0}", le4(100));
Console.Read();
}
}
}
输出:
101
101
101
101
101
参考:
1.《图解教程》P253