自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

Linq Func<T>簡單概述

開發(fā) 后端
這里介紹不能使用Linq Func<T>(以及T、Arg0……),因為它們返回的是布爾值。我需要更靈活的對象,簡單來說就是返回對象的對象,以及接收一些固定參數類型(例如Func<T>)的委托“重載”。

本文我們開始Linq利用表達式樹,并討論比較有趣的內容,即如何實現Linq Func<T>。

在Linq中,任何接收λ表達式(委托類型)的方法都可以轉換為接收相同委托類型的Expression<T>的方法,并且不需要更改客戶機代碼。例如:

  1. privatestaticvoid DoSomething(Predicate<Mock> predicate)  

可以替換為:

  1. privatestaticvoid DoSomething(  
  2. Expression<Predicate<Mock><Mock>> predicate) 

在上述兩種情況下,調用代碼可以是相同的λ表達式:

  1. DoSomething(x => x.Value > 25); 

這里發(fā)生的情況是,編譯器不會將指針傳入到第二個方法簽名的匿名委托中,而是生成以表達式樹的形式構建AST(抽象語法樹)的IL代碼。如果您打開Reflector(我的類型反射類的名字也由此而來,它是任何高級開發(fā)人員都應該經常使用的最偉大的工具)并取消對DoSomething的方法調用,就可以看到:

  1. ParameterExpression expression1 =  
  2. Expression.Parameter(typeof(Mock), "x");  
  3. Program.DoSomething(  
  4. Expression.Lambda<Predicate<Mock>>(  
  5. Expression.GT(Expression.Field(  
  6. expression1, fieldof(Mock.Value)),  
  7. Expression.Constant(0x19, typeof(int))),  
  8. newParameterExpression[]{expression1 })  
  9. );  

這里您可以看到編譯器如何使用Expression類上的靜態(tài)方法構建整個表達式(我對API的詳細看法另外單獨討論)。當然,在方法實現中,您可以檢查相同的樹并執(zhí)行任何想執(zhí)行的操作。***的Linq CTP包含一個非常酷的可視化工具,在運行時到達您的方法主體時可以用來查看表達式樹中的情況。到現在為止,您應該明白了我正在實現一個強類型反射:我接收一個表達式樹,并在其中搜索方法調用節(jié)點(或者,對于屬性和字段來說是成員訪問)。下面是Method<>方法的實現:

  1. publicstaticMethodInfo Method<TDeclaringType>(  
  2. Expression<Operation> method)  
  3. {  
  4. return GetMethodInfo(method);  
  5. }  
  6.    
  7. privatestaticMethodInfo GetMethodInfo(Expression method)  
  8. {  
  9. LambdaExpression lambda = method asLambdaExpression;  
  10. if (lambda == null)  
  11. thrownewArgumentNullException("method");  
  12.  
  13. MethodCallExpression methodExpr = null;  
  14.    
  15. // 我們的Operation<T>返回一個對象,故首先可以聲名一  
  16. // 個類型轉換(如果方法無返回對象)或直接方法調用。  
  17. if (lambda.Body.NodeType == ExpressionType.Cast)  
  18. {  
  19. // 類型轉換是一個一元操作,而操作數是一個方法調用表達式。  
  20. methodExpr = ((UnaryExpression)lambda.Body).  
  21. Operand asMethodCallExpression;  
  22. }  
  23. elseif (lambda.Body.NodeType == ExpressionType.MethodCall ||  
  24. lambda.Body.NodeType == ExpressionType.MethodCallVirtual)  
  25. {  
  26. methodExpr = lambda.Body asMethodCallExpression;  
  27. }  
  28. if (methodExpr == null)  
  29. thrownewArgumentException("method");  
  30. return methodExpr.Method;  
  31. }  

我創(chuàng)建的就是Operation委托類型。不能使用Linq Func<T>(以及T、Arg0……),因為它們返回的是布爾值。我需要更靈活的對象,簡單來說就是返回對象的對象,以及接收一些固定參數類型(例如Func<T>)的委托“重載”。因此我得到如下內容:

  1. publicdelegateobjectOperation();  
  2. publicdelegateobjectOperation<T>(T declaringType);  
  3. publicdelegateobjectOperation(T declaringType, A0 arg0);  
  4. ...  

注意,API的用戶從來都不會知道這些委托類型的對象的存在,就像查詢操作符的用戶從不知道Func<T>的存在一樣。我希望將來這些委托能夠消失,而代之以更好的東西(可能是publicdelegateobject Operation < params T> ;))。此外,注意我是如何將新的參數類型的參數添加到T“后面”的,T是重載的通用轉換,與Linq Func<T>中的功能正好相反。

【編輯推薦】

  1. LINQ to SQL Table淺談
  2. Linq語句問題的解決方法
  3. Ling to sql更新實體概述
  4. Linq實體繼承簡單描述
  5. Linq Library概述
責任編輯:佚名 來源: IT168
相關推薦

2009-09-10 16:28:17

LINQ查詢

2009-09-09 16:07:16

Linq實體關系

2009-09-11 10:16:07

Linq匿名類型

2009-09-15 13:37:24

Linq To Sql

2009-09-17 11:35:40

Linq匿名類型

2009-09-15 13:53:53

Linq To Sql

2009-09-14 10:54:07

LINQ解決方案

2009-09-11 09:53:16

Linq查詢表達式

2009-09-10 13:42:47

Linq UserIn

2009-09-10 11:10:21

Linq Librar

2009-09-08 11:25:42

Linq foreac

2009-09-08 16:08:44

Linq使用order

2009-09-18 16:07:10

Linq Where操

2009-09-18 16:20:36

LINQ基礎

2009-09-11 12:13:40

LINQ to SQL

2009-09-14 09:55:55

Linq基本語法

2009-09-14 15:15:45

LINQ技術

2009-09-16 17:21:53

LINQ遍歷

2009-09-18 13:44:38

LINQ設計模式

2009-09-09 16:01:21

Linq實體繼承使用
點贊
收藏

51CTO技術棧公眾號