草庐IT

expression-trees

全部标签

c# - 如何从字符串中为深层属性创建表达式树/lambda

给定一个字符串:“Person.Address.Postcode”我希望能够在Person的实例上获取/设置此邮政编码属性。我怎样才能做到这一点?我的想法是用“。”分割字符串。然后遍历各个部分,寻找前一个类型的属性,然后构建一个看起来像这样的表达式树(对伪语法表示歉意):(person=>person.Address)address=>address.Postcode不过,我在创建表达式树时遇到了真正的麻烦!如果这是最好的方法,有人可以建议如何去做,还是有更简单的替代方法?谢谢安德鲁publicclassPerson{publicintAge{get;set;}publicstring

c# - 使用 "Expression Bodied Functions and Properties"有什么好处

这个问题在这里已经有了答案:Expression-bodiedfunctionmembersefficiencyandperformanceinC#6.0(2个答案)关闭6年前。我确实看到很多人使用该新功能,但使用这些表达式有什么好处?Examples:publicoverridestringToString()=>string.Format("{0},{1}",First,Second);publicstringText=>string.Format("{0}:{1}-{2}({3})",TimeStamp,Process,Config,User);这个问题不同于thisone,因为

c# - 在 .Net Core 2.1 中使用 FirstOrDefault 时引发的 System.Linq.Expressions 异常

我收到了~300多个异常,这些异常在我的服务器输出中被标记为垃圾邮件:Exceptionthrown:'System.ArgumentException'inSystem.Linq.Expressions.dll我使用的查询如下:Accountaccount=_accountContext.Account.Include(i=>i.Currency).Include(i=>i.Unlocks).Include(i=>i.Settings).Include(i=>i.Friends).FirstOrDefault(a=>a.FacebookUserID==facebookUserID);

c# - Entity Framework 不会在 SQL Express (MDF) 中保留数据

我正在使用EntityFramework开发应用程序并将数据存储在.mdf数据库中。我的代码可以读取数据,显然它也可以保存,但只是表面上。它没有错误,当程序运行时它就像数据已保存一样,例如我可以保存一个对象,处理上下文,创建一个新对象,然后当我搜索我的对象时它就在那里!但是当我查询数据库以查看存储的数据时,那里什么也没有。如果我关闭应用程序并再次运行它,所有数据都将消失。这是我为测试而编写的示例代码:using(DatabaseEntitiese=newDatabaseEntities()){for(inti=0;ius=e.User.Where(x=>x.ID();foreach(U

c# - 基于子实体的属性构建 OrderBy Lambda 表达式

我正在尝试使用lambda表达式生成一个LINQOrderBy子句,并将实体的列名称作为字符串输入(在下面的“sortOn”变量中)。下面的代码适用于生成lambda的sortOn值,如“代码”p=>p.Code但我还想对lambda可能所在的子实体进行排序p=>p.Category.Description所以在这种情况下,我只想设置sortOn="Category.Description"并生成正确的lamdba表达式。这可能吗?我们欢迎任何有关执行此操作的最佳方法的建议。此代码适用于简单的情况:varparam=Expression.Parameter(typeof(Product

c# - 替换表达式主体中的参数名称

我正在尝试基于规范对象动态构建表达式。我创建了一个ExpressionHelper类,它有一个私有(private)表达式,如下所示:privateExpression>expression;publicExpressionHelper(){expression=(Expression>)(a=>true);}然后是一些简单的方法如下:publicvoidAnd(Expression>exp);我正在努力处理And方法的主体。我基本上想从exp中删除主体,用expression中的参数替换所有参数,然后将其附加到expression的末尾body和AndAlso。我这样做过:varne

c# - 什么更快 : expression trees or manually emitting IL

创建直接发出IL的方法与构建表达式树之间是否存在性能差异? 最佳答案 优秀而复杂的问题。最近之前,Expression根本无法处理所有情况-因此在许多情况下这是毫无疑问的。这随着Expression.Block等的引入而改变。在大多数“常见”情况下,Expression的使用可能绰绰有余,但我承认我没有精确的测量,仅仅是因为虽然我做了很多IL,但我还针对没有像Expression(当然不是Expression.Block)这样的奢侈品的下层框架。我也倾向于使用复杂的“装饰器”方法,这些方法可以很好地在IL中堆叠体操,但不一定进入Ex

c# - 如何在已编译的表达式树中调试或设置 break 语句?

当外部库包含LINQ提供程序时,它会在执行动态表达式树时抛出异常,我该如何在抛出该表达式时中断?例如,我使用第三方LINQ2CRM提供商,它允许我调用Max()IQueryable的方法|,但当它抛出一个InvalidCastException,当抛出异常时,我无法当场中断,因此很难查看堆栈跟踪,因为当调试器在我的代码中中断它时,它已经展开。我已经为提到的异常设置了“breakonthrow”。我的调试设置是:澄清我想要打破的确切位置。我不想在LINQ表达式中中断,而是想在执行表达式树时中断,或者换句话说,在执行IQueryable时中断。扩展方法Max()调用LINQ提供程序提供的覆

c# - 在没有数据库上下文的情况下将 LINQ 表达式转换为 SQL 文本

无论是LINQtoSQL还是LINQtoEntities都已经具备将LINQ转换为SQL文本字符串的能力。但我希望我的应用程序在不使用数据库上下文的情况下进行转换——这反过来意味着一个事件的数据库连接——这两个提供程序都需要。我想将LINQ表达式转换为用于WHERE和ORDERBY子句的等效SQL字符串,而不依赖于DB上下文,以使以下存储库接口(interface)工作:publicinterfaceIStorewhereT:class{voidAdd(Titem);voidRemove(Titem);voidUpdate(Titem);TFindByID(Guidid);//sure

c# - 获取 MethodCallExpression 的参数值

如何获取MethodCallExpression的参数值?今天我这样做了,但是速度不够快:privatestaticobjectGetArgumentValue(Expressionelement){LambdaExpressionl=Expression.Lambda(Expression.Convert(element,element.Type));returnl.Compile().DynamicInvoke();}此方法从表达式获取值,但如果我知道表达式总是来自MethodCallExpression.Arguments,我可以优化它吗?我想我可以把第一行改成这样,但我不知道它