我试图从Select返回一个表达式,所以我有一个返回表达式的表达式(我认为-可能是一个返回表达式的lambda,我不确定术语)
如果我创建一个显式指定表达式类型的变量,那么它的工作方式如下所示:
housingDivisions.Select(id => {
Expression<Func<Document, bool>> expression = d => d.HousingDivisions.Any(h => h.HousingDivisionId == id);
return expression;
})
然而,这段代码看起来是等价的(而且不太冗长)
housingDivisions.Select(id => d => d.HousingDivisions.Any(h => h.HousingDivisionId == id))
但是会导致编译错误:
尝试显式指定类型参数。
有没有办法在不创建不必要的变量的情况下对其进行编译?
发布于 2019-06-21 01:58:52
问题是d => ...
的类型d
和委托类型都是未知的,不能从任何地方假定。您可以通过实例化委托类型来一次性解决这两个问题:
housingDivisions.Select(id => new Func<Document, bool>(d => d.HousingDivisions.Any(h => h.HousingDivisionId == id)))
如果您绝对需要将类型转换为表达式树,则可以通过以下方式转换为该类型:
housingDivisions.Select(id => (Expression<Func<Document, bool>>)(d => d.HousingDivisions.Any(h => h.HousingDivisionId == id)))
编译器建议显式指定参数。就我个人而言,我认为这种方式有点冗长。但是它看起来像这样:
housingDivisions.Select<int, Expression<Func<Document, bool>>>(id => d => d.HousingDivisions.Any(h => h.HousingDivisionId == id));
下面是一个选择表达式的扩展方法:
public static IEnumerable<Expression<Func<ExprArg, Result>>> SelectExpr<TSource, ExprArg, Result>(this IEnumerable<TSource> source, Func<TSource, ExprArg, Result> func)
{
return source.Select((o) => (Expression<Func<ExprArg, Result>>)((arg) => func(o, arg)));
}
// Use:
housingDivisions.SelectExpr((int id, Document d) => d.HousingDivisions.Any(h => h.HousingDivisionId == id));
https://stackoverflow.com/questions/56691164
复制相似问题