码迷,mamicode.com
首页 > 其他好文 > 详细

解析 Lambda 表达式

时间:2015-05-24 15:25:43      阅读:130      评论:0      收藏:0      [点我收藏+]

标签:

我们先创建一个表达式树:

Expression<Func<int, int, int>> expression = (a,b) => a + b;
我们的例子是一个Expression<TDelegate>。Expression<TDelegate>类有四个属性:
  • Body: 得到表达式的主体。
  • Parameters: 得到lambda表达式的参数.
  • NodeType: 获取树的节点的ExpressionType。共45种不同值,包含所有表达式节点各种可能的类型,例如返回常量,例如返回参数,例如取两个值的小值(<),例如取两个值的大值(>),例如将值相加(+),等等。
  • Type: 获取表达式的一个静态类型。在这个例子里,表达式的类型是Func<intintint>

下面就写Code来解析

技术分享
            Expression<Func<int, int, int>> expression = (a, b) => a + b;
            BinaryExpression body = (BinaryExpression)expression.Body;
            ParameterExpression left = (ParameterExpression)body.Left;
            ParameterExpression right = (ParameterExpression)body.Right;
            Console.WriteLine(expression.Body);
            Console.WriteLine(" 表达式左边部分: " + "{0}{4} 节点类型: {1}{4} 表达式右边部分: {2}{4} 类型: {3}{4}", left.Name, body.NodeType, right.Name, body.Type, Environment.NewLine);
View Code

输出:

  (a + b)
  表达式左边部分: a
  节点类型:  Add
  表达式右边部分: b
  类型: System.Int32

我们可以调用Compile()方法来生成委托对象

int res = expression.Compile()(3, 5); 

这段代码会输出值8,跟本文最初声明的lambda函数的执行结果一样。

 

Expression参考博客:http://www.cnblogs.com/Ninputer/archive/2009/08/28/expression_tree1.html

解析 Lambda 表达式

标签:

原文地址:http://www.cnblogs.com/zuqing/p/4525831.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!