var list = new [] { "aa", "bb", "ac" }; var result = Array.FindAll(list, s => (s.IndexOf("a") > -1)); foreach (var v in result) Console.WriteLine(v);
|
其实和2.0中的匿名方法差不多,都是用于产生内联方法,只不过Lambda表达式的语法更为简洁。语法如下:
(参数列表) => 表达式或者语句块
其中:
参数个数:可以有多个参数,一个参数,或者无参数。
表达式或者语句块:这部分就是我们平常写函数的实现部分(函数体)。
前面的示例分别是1个参数的例子,下面结合扩展方法来一个复杂的例子
--------------------------------------------------------------
public delegate int mydg(int a, int b);
public static class LambdaTest
{
public static int oper(this int a, int b, mydg dg)
{
return dg(a, b);
}
}
Console.WriteLine(1.oper(2, (a, b) => a + b));
Console.WriteLine(2.oper(1, (a, b) => a - b));
----------------------------------------------------
一个简单的和一个利用委托的复杂的。
说下自己的理解:
-----------------
其实和2.0中的匿名方法差不多,都是用于产生内联方法,只不过Lambda表达式的语法更为简洁。语法如下:
(参数列表) => 表达式或者语句块
其中:
参数个数:可以有多个参数,一个参数,或者无参数。
表达式或者语句块:这部分就是我们平常写函数的实现部分(函数体)。
前面的示例分别是1个参数的例子,下面结合扩展方法来一个复杂的例子
中的
(参数列表) => 表达式或者语句块 参数列表就是平时我们写一个函数传入的参数而已。
而表达式或者语句块就是我们函数的函数体
如上
1.oper(2, (a, b) => a + b));
(a,b) 对应上述说明应该为函数体,由于有委托 public delegate int mydg(int a, int b);
必须传入2个函数参数,而 a+b就是委托里的方法内容的。这里利用Lambda表达是反而更加简单了。