Resharper声称使用带有种子的LINQ Aggregate表达式总是错误的
本文关键字:Aggregate LINQ 表达式 错误 种子 Resharper | 更新日期: 2023-09-27 17:59:53
在下面的代码中,Resharper声称表达式currMax == null
总是false。
public Read Read1
{
get
{
return Reads.Where(read => !read.IsIndex)
.Aggregate((Read)null, (currMax, read) => currMax == null || read.Length > currMax.Length ? read : currMax);
}
}
当调用Aggregate
中lambda表达式的第一次迭代执行时,我希望currMax == null
为真,因为(Read)null
是种子。Resharper知道上游Where
需要结果IEnumerable
中的非空Read
对象,因为我正在访问Read
类的IsIndex
属性。重拍只是没有考虑到Aggregate
的种子参数吗?
编辑:我在这里提交了一份错误报告https://youtrack.jetbrains.com/issue/RSRP-443055
从ILSpy中Aggregate
的反汇编来看,ReSharper似乎错了。
public static TAccumulate Aggregate<TSource, TAccumulate>(
this IEnumerable<TSource> source,
TAccumulate seed,
Func<TAccumulate, TSource, TAccumulate> func)
{
if (source == null)
{
throw Error.ArgumentNull("source");
}
if (func == null)
{
throw Error.ArgumentNull("func");
}
TAccumulate tAccumulate = seed;
foreach (TSource current in source)
{
tAccumulate = func(tAccumulate, current);
}
return tAccumulate;
}
显然,删除null
检查将导致空引用异常。
这确实是ReSharper的可空性分析中的一个错误。你能向YouTrack报告吗?
同时,您可以使用// ReSharper disable once ConditionIsAlwaysTrueOrFalse
抑制此警告。