jjzjj

expression-trees

全部标签

c# - 表达式树中的绑定(bind)参数

我想知道如何将参数绑定(bind)到表达式树中的值有点像Expression>e1=(x,y)=>x==y;然后我想绑定(bind)y,同时将其保留为单个表达式。一个明显的尝试是类似Expresion>e2=x=>e1(x,"FixedValueHere");但这会将我的表达式变成一个Invoke节点。有没有一种方法可以在我的第一个表达式中简单地绑定(bind)一个参数,同时获取第二个表达式的签名? 最佳答案 Expression>e1=(x,y)=>x==y;varswap=newExpressionSubstitute(e1.P

c# - 这是 ExpressionTrees 错误吗? #2

看起来ExpressionTrees编译器在许多行为上应该接近C#规范,但与C#不同的是,它不支持从decimal到任何enum-type的转换:usingSystem;usingSystem.Linq.Expressions;classProgram{staticvoidMain(){Funcconverter1=x=>(ConsoleColor)x;ConsoleColorc1=converter1(7m);//fineExpression>expr=x=>(ConsoleColor)x;//System.InvalidOperationExceptionwasunhandled/

c# - 在 Visual C# 2008 Express Edition 中设置 32 位 x86 构建目标?

我正在构建一个加载32位COMdll的C#应用程序。编译后的应用程序在32位Windows上运行良好,但在64位Windows上运行失败,因为它无法加载32位COM。有没有办法在VC#2008ExpressEdition中设置32位构建目标?或者,是否有办法强制编译为AnyCPU构建目标的.NET应用程序在64位Windows上以32位模式运行? 最佳答案 为了后代,这里是adrian链接到的论坛帖子:InVC#Express,thispropertyismissing,butyoucanstillcreateanx86config

c# - 表达式树 - Math.Max 替换

当我使用表达式树来替换一个方法时,比如Math.Max,看起来它在表达式树中成功地替换了它。但是当我在EntityFramework中使用它时,它抛出一个关于EntityFramework不支持Math.Max的异常。但我明确地替换了它。有人知道为什么吗?以及修复代码的方法?usingSystem;usingSystem.Collections.Generic;usingSystem.Linq;usingSystem.Linq.Expressions;namespaceConsoleApplication1{publicstaticclassCalculateDatabase{publ

c# - 在 System.Linq.Expressions 中不带大小写(但使用默认值)切换

我尝试使用System.Linq.Expressions创建一个switch表达式:varvalue=Expression.Parameter(typeof(int));vardefaultBody=Expression.Constant(0);varcases1=new[]{Expression.SwitchCase(Expression.Constant(1),Expression.Constant(1)),};varcases2=newSwitchCase[0];varswitch1=Expression.Switch(value,defaultBody,cases1);vars

c# - 如何为 IQueryable.Count 获取 ToTraceString

我使用((ObjectQuery)IQueryable).ToTraceString()获取和调整将由LINQ执行的SQL代码。我的问题是,与大多数IQueryable方法不同,IQueryable.Count定义如下:publicstaticintCount(thisIQueryablesource){return(int)source.Provider.Execute(Expression.Call(typeof(Queryable),"Count",newType[]{source.ElementType},source.Expression));}执行查询而不编译并返回IQue

c# - 是否可以有一个 out ParameterExpression?

我想定义一个带有out参数的Lambda表达式。有可能做到吗?下面是我尝试过的C#.Net4.0控制台应用程序的代码片段。正如您在程序25中看到的那样,我可以使用lambda表达式来定义具有输出参数的委托(delegate),但是,当我想使用linq表达式执行相同操作时,程序24中的代码失败并显示:System.ArgumentExceptionwasunhandledMessage=ParameterExpressionoftype'System.Boolean'cannotbeusedfordelegateparameteroftype'System.Boolean&'Source

C#、Linq2Sql : Is it possible to concatenate two queryables into one?

我有一个可查询的,我在其中使用了各种Where和WhereBetween将集合缩小到特定集合的语句。现在我需要添加一种Where||WhereBetween。换句话说,我不能像到目前为止那样将它们链接在一起,因为那样可以用作And。那么,我该怎么做呢?我看到两种可能性:创建两个可查询对象,一个使用Where,另一个使用WhereBetween。然后连接它们。不知道这是否可能?此外,虽然不是我的特殊情况,但你很可能会得到重复项......以某种方式将Where表达式和在WhereBetween中创建的表达式与某种Or合并。第一个,如前所述,我什至不确定是否可能。如果是的话,我不太确定这是

c# - 如何针对集合调用 Expression<Func<Entity, bool>>

我有一个从存储库模式定义存储库的接口(interface):interfaceIRepository{ListGetAllCustomers(Expression>expression);}我已经在EntityFramework上实现了它:classEntityFrameworkRepository{publicListGetAllCustomers(Expression>expression){returnDBContext.Customers.Where(expression).ToList();}}这似乎工作得很好,它允许我做类似的事情:varcustomers=entityFr

c# - Expression<TDelegate>.Compile 和垃圾收集

当我将表达式编译成可执行代码并获取委托(delegate)时-如果不再存在对该委托(delegate)的引用,代码是否会被垃圾收集?有这方面的文档吗?因为我在MSDN中没有找到任何有用的东西。 最佳答案 是的,代码可以被垃圾回收。当您对T的表达式调用编译时,代码将编译为DynamicMethod,并且那些有资格进行垃圾收集。确实在MSDN上没有说明,但您可以查看DLR中Expression.Compile的实现,这是.net4.0附带的内容:http://dlr.codeplex.com/SourceControl/changese