函数的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表达式没有任何问题,它运行良好。我只是想创建一个函数,用函数的名称替换表达式,使代码看起来更短、更易于维护。
允许您使用新传递的值重用函数体的一个选项是在类级函数中生成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;