Linq中如何实现Linq Func<T>

发布时间:2021-12-02 09:23:15 作者:小新
来源:亿速云 阅读:135

小编给大家分享一下Linq中如何实现Linq Func<T>,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

在Linq中,任何接收λ表达式(委托类型)的方法都可以转换为接收相同委托类型的Expression<T>的方法,并且不需要更改客户机代码。例如:

privatestaticvoid DoSomething(Predicate<Mock> predicate)

可以替换为:

privatestaticvoid DoSomething(  Expression<Predicate<Mock><Mock>> predicate)

在上述两种情况下,调用代码可以是相同的λ表达式:

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

这里发生的情况是,编译器不会将指针传入到第二个方法签名的匿名委托中,而是生成以表达式树的形式构建AST(抽象语法树)的IL代码。如果您打开Reflector(我的类型反射类的名字也由此而来,它是任何高级开发人员都应该经常使用的最伟大的工具)并取消对DoSomething的方法调用,就可以看到:

ParameterExpression expression1 =  Expression.Parameter(typeof(Mock), "x");  Program.DoSomething(  Expression.Lambda<Predicate<Mock>>(  Expression.GT(Expression.Field(  expression1, fieldof(Mock.Value)),  Expression.Constant(0x19, typeof(int))),  newParameterExpression[]{expression1 })  );

这里您可以看到编译器如何使用Expression类上的静态方法构建整个表达式(我对API的详细看法另外单独讨论)。当然,在方法实现中,您可以检查相同的树并执行任何想执行的操作。***的Linq CTP包含一个非常酷的可视化工具,在运行时到达您的方法主体时可以用来查看表达式树中的情况。到现在为止,您应该明白了我正在实现一个强类型反射:我接收一个表达式树,并在其中搜索方法调用节点(或者,对于属性和字段来说是成员访问)。下面是Method<>方法的实现:

publicstaticMethodInfo Method<TDeclaringType>(  Expression<Operation> method)  {  return GetMethodInfo(method);  }     privatestaticMethodInfo GetMethodInfo(Expression method)  {  LambdaExpression lambda = method asLambdaExpression;  if (lambda == null)  thrownewArgumentNullException("method");   MethodCallExpression methodExpr = null;     // 我们的Operation<T>返回一个对象,故首先可以声名一  // 个类型转换(如果方法无返回对象)或直接方法调用。  if (lambda.Body.NodeType == ExpressionType.Cast)  {  // 类型转换是一个一元操作,而操作数是一个方法调用表达式。  methodExpr = ((UnaryExpression)lambda.Body).  Operand asMethodCallExpression;  }  elseif (lambda.Body.NodeType == ExpressionType.MethodCall ||  lambda.Body.NodeType == ExpressionType.MethodCallVirtual)  {  methodExpr = lambda.Body asMethodCallExpression;  }  if (methodExpr == null)  thrownewArgumentException("method");  return methodExpr.Method;  }

我创建的就是Operation委托类型。不能使用Linq Func<T>(以及T、Arg0……),因为它们返回的是布尔值。我需要更灵活的对象,简单来说就是返回对象的对象,以及接收一些固定参数类型(例如Func<T>)的委托“重载”。因此我得到如下内容:

publicdelegateobjectOperation();  publicdelegateobjectOperation<T>(T declaringType);  publicdelegateobjectOperation(T declaringType, A0 arg0);  ...

注意,API的用户从来都不会知道这些委托类型的对象的存在,就像查询操作符的用户从不知道Func<T>的存在一样。我希望将来这些委托能够消失,而代之以更好的东西(可能是publicdelegateobject Operation < params T> ;))。此外,注意我是如何将新的参数类型的参数添加到T“后面”的,T是重载的通用转换,与Linq Func<T>中的功能正好相反。

以上是“Linq中如何实现Linq Func<T>”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!

推荐阅读:
  1. 数据结构(12)_树的概念及通用树的实现
  2. C#中的Action<>和Func<>怎么用

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

linq

上一篇:怎样使用PowerDesigner 15对现有数据库进行反向工程

下一篇:SpringBoot2.0整合tk.mybatis异常怎么解决

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》