拉姆达表达式(Lambda Expression)
可以算是一种匿名方法的实现吧。
在C# 2.0中引入了匿名方法的概念,我们可以写下如下代码:
其中i=>(i%2)==0就是我们说的Lambda Expression,在这里它就起到了原来匿名方法的作用,同时提升了代码的可阅读性。
下面是一个复杂一点的Lambda Expression的例子:
看了这个例子应该可以自己动手写一些东西了吧(下楼买瓶可乐去也)
这里还有一个有趣的东西:Lambda Expression Tree(拉姆达表达式树)
这是一种用来在运行时把表达式作为数据的技术,我们可在运行时灵活的控制和改变表达式,
增强程序的灵活性!
还是看代码吧,这样直接一点:
输出:
(LT (Multiply n 3) 5)
通过这种技术,我们对于数据和数据表达式的操作可以变得更加轻松,不用动不动就是写方法了。
可以算是一种匿名方法的实现吧。
在C# 2.0中引入了匿名方法的概念,我们可以写下如下代码:
1class Program
2{
3static void TestLambdaExpression()
4{
5 List<int> list = new List<int>();
6
7 list.Add(1);
8 list.Add(2);
9 list.Add(3);
10 list.Add(4);
11
12 List<int> evenNumbers = list.FindAll(delegate(int i) { return (i % 2) == 0; } );
13
14 foreach (int evenNumber in evenNumbers)
15 {
16 Console.WriteLine(evenNumber);
17 }
18}
19}
20
21static void Main(string[] args)
22{
23TestLambdaExpression();
24}
25
2{
3static void TestLambdaExpression()
4{
5 List<int> list = new List<int>();
6
7 list.Add(1);
8 list.Add(2);
9 list.Add(3);
10 list.Add(4);
11
12 List<int> evenNumbers = list.FindAll(delegate(int i) { return (i % 2) == 0; } );
13
14 foreach (int evenNumber in evenNumbers)
15 {
16 Console.WriteLine(evenNumber);
17 }
18}
19}
20
21static void Main(string[] args)
22{
23TestLambdaExpression();
24}
25
匿名方法避免了一些“极小函数”的出现,适当使用可以提高代码的可阅读性,显得清爽一点。
(List的FindAll方法需要一个Delegate参数,所以我们可以这样谢哈)
在C# 3.0中,我们可以这样写:
1static void TestLambdaExpression()
2{
3var list = new List<int>();
4
5 list.Add(1);
6 list.Add(2);
7 list.Add(3);
8 list.Add(4);
9
10var evenNumbers = list.FindAll(i => (i % 2) == 0);
11
12foreach (int evenNumber in evenNumbers)
13{
14 Console.WriteLine(evenNumber);
15 }
16}
2{
3var list = new List<int>();
4
5 list.Add(1);
6 list.Add(2);
7 list.Add(3);
8 list.Add(4);
9
10var evenNumbers = list.FindAll(i => (i % 2) == 0);
11
12foreach (int evenNumber in evenNumbers)
13{
14 Console.WriteLine(evenNumber);
15 }
16}
其中i=>(i%2)==0就是我们说的Lambda Expression,在这里它就起到了原来匿名方法的作用,同时提升了代码的可阅读性。
下面是一个复杂一点的Lambda Expression的例子:
1fruit.FilterBy((string name, double price) => name == "banana" && price < 2.00);
看了这个例子应该可以自己动手写一些东西了吧(下楼买瓶可乐去也)
这里还有一个有趣的东西:Lambda Expression Tree(拉姆达表达式树)
这是一种用来在运行时把表达式作为数据的技术,我们可在运行时灵活的控制和改变表达式,
增强程序的灵活性!
还是看代码吧,这样直接一点:
1using System.Expressions;
2
3static void Main(string[] args)
4{
5 Expression<Func<int, bool>> filter = n => (n * 3) < 5;
6
7 BinaryExpression lt = (BinaryExpression) filter.Body;
8 BinaryExpression mult = (BinaryExpression) lt.Left;
9 ParameterExpression en = (ParameterExpression) mult.Left;
10 ConstantExpression three = (ConstantExpression) mult.Right;
11 ConstantExpression five = (ConstantExpression) lt.Right;
12
13 Console.WriteLine("({0} ({1} {2} {3}) {4})", lt.NodeType,
14 mult.NodeType, en.Name, three.Value, five.Value);
15}
2
3static void Main(string[] args)
4{
5 Expression<Func<int, bool>> filter = n => (n * 3) < 5;
6
7 BinaryExpression lt = (BinaryExpression) filter.Body;
8 BinaryExpression mult = (BinaryExpression) lt.Left;
9 ParameterExpression en = (ParameterExpression) mult.Left;
10 ConstantExpression three = (ConstantExpression) mult.Right;
11 ConstantExpression five = (ConstantExpression) lt.Right;
12
13 Console.WriteLine("({0} ({1} {2} {3}) {4})", lt.NodeType,
14 mult.NodeType, en.Name, three.Value, five.Value);
15}
输出:
(LT (Multiply n 3) 5)
通过这种技术,我们对于数据和数据表达式的操作可以变得更加轻松,不用动不动就是写方法了。