C# 基于属性从列表中删除项
我有一个奇怪的情况,代码行的执行时间超过5分钟,我无法理解为什么:C# 基于属性从列表中删除项,c#,asp.net,asp.net-mvc,linq,asp.net-mvc-4,C#,Asp.net,Asp.net Mvc,Linq,Asp.net Mvc 4,我有一个奇怪的情况,代码行的执行时间超过5分钟,我无法理解为什么: var cleansedTransactions = competitorTransactions.Where(i => !endedItemsLocal.Contains(i.ItemID)).ToList(); 进一步解释: competitorTransactions - is a list of transactions which in this case contains 921 record inside
var cleansedTransactions = competitorTransactions.Where(i => !endedItemsLocal.Contains(i.ItemID)).ToList();
进一步解释:
competitorTransactions - is a list of transactions which in this case contains 921 record inside it;
endedItemsLocal - is an IEnumerable<string> - which in this case contains 8 records
competitorTransactions-是一个事务列表,在本例中,其中包含921条记录;
endedItemsLocal—是一个IEnumerable—在本例中包含8条记录
我在这里试图做的是从“competitorTransactions”列表中删除“endedItemsLocal”(IEnumerable)中包含的所有项目
为什么执行需要5-9分钟?我可以说,如果这两个收藏包含数百万张唱片,需要9分钟,但只有921和8张,这让我疯狂,我不明白为什么需要这么长时间?有人能帮我吗 您不应该使用IEnumerable,因为它是惰性加载的。使用endedItemsLocal数组并使用该集合,这将分配一个集合,从而提高速度。您不应该使用IEnumerable,因为它是延迟加载的。使用endedItemsLocal数组并使用该集合,这将分配一个集合,从而提高速度。将
endedItemsLocal
存储在列表中,您对它进行了921次迭代。@vasily.sib是的,我现在遇到了。。我将在列表中尝试它^^storeendedItemsLocal
,您对它进行了921次迭代。@vasily.sib是的,我现在想到了。。我试试看,哈密特,托利斯特还是托雷?哪一个更有效?:)<代码>列表
在内部使用T[]
,因此它几乎是相同的。这取决于您想对集合执行什么操作。如果您想稍后向其中添加更多项目,最好将其作为列表,否则vasily.sib的行为是正确的。Hamit、.ToList还是ToArray?哪一个更有效?:)<代码>列表
在内部使用T[]
,因此它几乎是相同的。这取决于您想对集合执行什么操作。如果您想稍后向集合中添加更多项,则最好将其作为列表,否则vasily.sib的行为是正确的。