函数的Lambda表达式<;T、 TResult>;

本文关键字:TResult gt lt Lambda 表达式 函数 | 更新日期: 2023-09-27 18:28:34

如何将optionObject.Forms.First(f => f.FormId == formId).MultipleIteration中的lambda表达式写入Func,以便在结尾处获得类似的内容

Func<FormObject, bool> FormID = f => f.formID == passedVal;

然后在第一个表达式中使用它来获得类似的东西

optionObject.Forms.First(FormID).MultipleIteration

我试过

Func<FormObject, PassedVal, bool> FormID => formID == PassedVal;

但没有起作用
请注意lambda表达式没有任何问题,它运行良好。我只是想创建一个函数,用函数的名称替换表达式,使代码看起来更短、更易于维护。

函数的Lambda表达式<;T、 TResult>;

允许您使用新传递的值重用函数体的一个选项是在类级函数中生成Func<FormData, bool>实例:

public static Func<FormObject, bool> CreateFormValidFunc(int validId)
{
    return f => f.formID == validId;
}

然后你可以这样使用它:

optionObject.Forms.First(CreateFormValidFunc(passedVal)).MultipleIteration
optionObject.Forms.First(CreateFormValidFunc(2)).MultipleIteration

一个有趣的附带说明是,int Foo => 0;是"表达式体属性"语法(C#6.0中的新语法),您的尝试可能与之匹配,足以使错误消息变得混乱。

您可以使用表达式体方法将验证函数生成器简化为:

public static Func<FormObject, bool> CreateFormValidFunc(int validId) => f => f.formID == validId;

这篇文章可以帮助您:lambda表达式和var关键字

当我尝试使用var add = (x, y) => x + y;时,编译器需要能够将集合减少到x和y的一个类型(不完全正确,可能基类和派生类都适合),即使编译器能够计算出x和y,或者指定了类型,比如说int,你仍然会发现Expression>和Func都是可能的用于添加的类型。

在你的场景中,你可以使用这个:

Expression<Func<FormObject, bool>> FormID = f => f.formID == passedVal;