Lambda表达式转化为Func<T, TResult>函数

5

如何将 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表达式没有任何问题,它可以正常工作。我只是尝试创建一个函数来替换表达式,使用函数名称使代码看起来更短并易于维护。


4
不理解,请你详细说明问题。 - Xiaomin Wu
1
可能是Reuse of a LINQ query的重复问题。 - Hamid Pourjam
是的,这就像上面的LINQ链接重用一样,只是在这种情况下,要比较的值不是硬编码的,而是传递给使用表达式的方法的参数。 - Yoismel
你的 Func<FormObject, PassedVal, bool> 没有起作用的原因是,First 和类似方法所接受的 lambda 的签名需要是 Func<FormObject, bool>。由于你还想要参数化另一个值,31eee384 的答案看起来是最好的,也可能是唯一的方法。 - Ann L.
2个回答

3

一种让您可以使用新传递的值重复使用函数体的选项是在类级别函数中生成 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;

这个解决方案非常完美。谢谢大家。 - Yoismel

0

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

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

在你的情况下,你可以使用这个:

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

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接