使用ToList()
时,是否需要考虑性能影响?
我正在编写一个从目录中检索文件的查询,该查询如下:
string[] imageArray = Directory.GetFiles(directory);
但是,由于我更喜欢使用List<>
,所以我决定将...
List<string> imageList = Directory.GetFiles(directory).ToList();
那么,在决定进行这样的转换时,是否存在某种类型的性能影响需要考虑-或者只在处理大量文件时考虑?这是可以忽略不计的转换吗?
发布于 2013-03-20 14:22:55
ToList()
会创建一个新的列表,并将元素放入其中,这意味着执行ToList()
会产生相关的成本。在小集合的情况下,它的成本不会非常明显,但在使用ToList的情况下,拥有大量的集合可能会导致性能损失。
通常,您不应该使用ToList(),除非您所做的工作不能不将集合转换为列表。例如,如果您只想遍历集合,则不需要执行ToList
如果您正在对数据源(例如使用LINQ to SQL的数据库)执行查询,则执行ToList的成本要高得多,因为当您将ToList与LINQ to SQL配合使用时,而不是执行延迟执行,即在需要时加载项(这在许多情况下可能是有益的),它会立即将项从数据库加载到内存中
发布于 2013-03-20 14:25:14
ToList将创建一个新的列表,并将元素从原始源复制到新创建的列表中,因此唯一要做的就是从原始源复制元素,并依赖于源的大小
https://stackoverflow.com/questions/15516462
复制相似问题