LINQ Expression tree分析

本文向大家介绍LINQ Expression tree,可能好多人还不了解LINQ Expression tree,没有关系,看完本文你肯定有不少收获,希望本文能教会你更多东西。

专注于为中小企业提供成都网站建设、网站制作服务,电脑端+手机端+微信端的三站合一,更高效的管理,为中小企业轵城免费做网站提供优质的服务。我们立足成都,凝聚了一批互联网行业人才,有力地推动了上千余家企业的稳健成长,帮助中小企业通过网站建设实现规模扩充和转变。

LINQ Expression tree

一棵LINQ Expession tree在创建后就不可再改变。假如某个程序接收一棵Expression tree为参数,然后仅仅是用于生成别的形式的代码(例如SQL语句),那么这个不可改变性不会有什么影响。但如果一个程序想对一棵Expression tree进行修改该怎么办呢?解决方法是从来源的Expression tree复制出一棵新的树,在复制过程中根据自己的需要选择是直接复制原有节点还是创建修改了的节点。MSDN上有一个例子解释了如何实现这种需求,如何:修改表达式目录树。

更详细的LINQ Expression tree的讨论留待以后再说。先看代码:

 
 
 
  1. digraph ExpressionTree {  
  2.  
  3. node [fontsize=12, fontcolor=blue, font=Courier, shape=box]  
  4.  
  5. // node declarations  
  6. lambda [label="Lambda Expression"]  
  7.  
  8. anoFuncSig [label="Anonymous Function\nSignature"]  
  9. arrow [label="=>"]  
  10. anoFuncBody [label="Anonymous Function\nBody"]  
  11.  
  12. impFuncSig [label="Implicit Anonymous\nFunction Signature"]  
  13. expr [label="Expression"]  
  14.  
  15. impParam [label="Implicit Anonymous\nFunction Parameter"]  
  16. uexpr1 [label="Unary Expression"]  
  17.  
  18. neg [label="-"]  
  19. uexpr2 [label="Unary Expression"]  
  20.  
  21. id [label="Identifier:\nx"]  
  22.  
  23. simpName [label="Simple Name:\nx"]  
  24.  
  25. // relations  
  26.  
  27. lambda -> anoFuncSig  
  28. lambda -> arrow  
  29. lambda -> anoFuncBody  
  30.  
  31. {rank=same; anoFuncSig arrow anoFuncBody }  
  32.  
  33. anoFuncSig -> impFuncSig  
  34. anoFuncBody -> expr  
  35.  
  36. {rank=same; impFuncSig expr }  
  37.  
  38. impFuncSig -> impParam  
  39. expr -> uexpr1 [style=dashed]  
  40.  
  41. {rank=same; impParam uexpr1 }  
  42.  
  43. impParam -> id  
  44. uexpr1 -> neg  
  45. uexpr1 -> uexpr2  
  46.  
  47. {rank=same; id neg uexpr2 }  
  48.  
  49. uexpr2 -> simpName  

ast.dot: 

 
 
 
  1. digraph ExpressionTree {  
  2.  
  3. node [fontsize=12, fontcolor=blue, font=Courier, shape=box]  
  4. edge [fontsize=10, fontcolor=purple]  
  5. // node declarations  
  6. lambda [label="Lambda Expression"]  
  7.  
  8. param [label="Parameter:\nx"]  
  9. body [label="Unary Expression\n(Negation)"]  
  10.  
  11. param2 [label="Simple Name:\nx"]  
  12.  
  13. // relations  
  14.  
  15. lambda -> param [label="Signature"]  
  16. lambda -> body [label="Body"]  
  17.  
  18. {rank=same; param body }  
  19.  
  20. body -> param2  
  21. param -> param2 [label="(same node)", fontsize=8, style=dashed, dir=both]  

【编辑推荐】

  1. Linq结果集形状概述
  2. Linq存储过程返回详解
  3. Linq调用LoadProducts方法
  4. Linq使用数据表简单描述
  5. Linq对象引用简单介绍

网页题目:LINQ Expression tree分析
本文来源:http://www.csdahua.cn/qtweb/news28/305228.html

网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网