Jer*_*oen 7 linq asp.net optimization
我正在迭代一个包含大约1000个元素的匿名类型.
这里的问题是我的循环可能需要几乎3秒才能完成,而循环内部发生的时间不到1毫秒.有一千个元素,我认为循环必须在第二个内完成,而不是3.
有没有办法让它迭代更快?
// takes 1ms to complete
var x = tt.Where(p => p.Methods.Count() > 0 && p.PerWeek != this.Project.WorkDaysCount && !p.IsManual);
// takes almost 3 seconds to complete
foreach (var item in x)
{
// do stuff that takes < 1 ms
}
Run Code Online (Sandbox Code Playgroud)
Jon*_*eet 15
两个即时建议:
p.Methods.Count() > 0- 需要执行完整计数,即使您只需要知道是否有任何元素.请p.Methods.Any()改用.this.Project.WorkDaysCount在每次迭代时计算.我们不知道那里发生了什么的细节,但它可能很昂贵.预先计算它,并使用常量.这是改进的查询代码:
int workDaysCount = Project.WorkDaysCount;
var x = tt.Where(p => p.Methods.Any() &&
p.PerWeek != workDaysCount &&
!p.IsManual);
Run Code Online (Sandbox Code Playgroud)
正如其他人所说,查询构建本身没有花费任何重要时间的原因是它没有做任何实际工作.但是,知道这不会让它变得更快,当然:)
除此之外,我们还需要了解更多有关背景的信息.这是LINQ to Objects,LINQ to SQL还是其他什么?这是什么类型的tt?