日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
LINQ Expression tree分析

本文向大家介紹LINQ Expression tree,可能好多人還不了解LINQ Expression tree,沒有關(guān)系,看完本文你肯定有不少收獲,希望本文能教會你更多東西。

專注于為中小企業(yè)提供成都網(wǎng)站建設(shè)、網(wǎng)站制作服務(wù),電腦端+手機端+微信端的三站合一,更高效的管理,為中小企業(yè)軹城免費做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動了上千余家企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網(wǎng)站建設(shè)實現(xiàn)規(guī)模擴充和轉(zhuǎn)變。

LINQ Expression tree

一棵LINQ Expession tree在創(chuàng)建后就不可再改變。假如某個程序接收一棵Expression tree為參數(shù),然后僅僅是用于生成別的形式的代碼(例如SQL語句),那么這個不可改變性不會有什么影響。但如果一個程序想對一棵Expression tree進行修改該怎么辦呢?解決方法是從來源的Expression tree復(fù)制出一棵新的樹,在復(fù)制過程中根據(jù)自己的需要選擇是直接復(fù)制原有節(jié)點還是創(chuàng)建修改了的節(jié)點。MSDN上有一個例子解釋了如何實現(xiàn)這種需求,如何:修改表達式目錄樹。

更詳細(xì)的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結(jié)果集形狀概述
  2. Linq存儲過程返回詳解
  3. Linq調(diào)用LoadProducts方法
  4. Linq使用數(shù)據(jù)表簡單描述
  5. Linq對象引用簡單介紹

網(wǎng)站名稱:LINQ Expression tree分析
網(wǎng)頁網(wǎng)址:http://www.5511xx.com/article/dhopohj.html