强大的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