我试图通过用 linq 调用替换项目中的现有代码来精简 linq。在此方法中,我检查行列表中的条件,如果条件为真,则将该元素从行移至已处理行。
数据结构只是列表:
List<LineSegment2> lines;
List<LineSegment2> processedLines;
原始代码是:
for (int i = lines.Count - 1; i >= 0; i--)
{
if (lines[i].P2.x < sweepPosition)
{
processedLines.Add(lines[i]);
lines.RemoveAt(i);
}
}
我的 linq 代码是:
var toMove = lines.FindAll(x => x.P2.x < sweepPosition);
toMove.ForEach(x =>
{
processedLines.Add(x);
lines.Remove(x);
});
我的问题是:这个 linq 代码是否效率较低,因为它使用更多内存来创建临时列表“toMove”。有没有办法在不需要临时列表的情况下创建 linq 查询,或者原始代码总是更有效?