小记扩展方法的延迟执行
描述这样一个场景:
然后看一段模拟代码:
IList<int> cache = new List<int>();
int i = 0;
while(i<1000)
{
cache.Add(i);
i++;
}
var temp = cache.Take(100);
cache.Clear();
foreach (var p in temp)
{
Console.WriteLine(p);
}
int i = 0;
while(i<1000)
{
cache.Add(i);
i++;
}
var temp = cache.Take(100);
cache.Clear();
foreach (var p in temp)
{
Console.WriteLine(p);
}
这段代码用了 Take<T>() 这个扩展方法, 这里要说的是,要做好从cache里取出前面的N条数据的方法有很多,
但是如果你这样使用了Take<T>() 方法你就会发现,你的temp里面什么都没有,
原因在与Take<T>() 是延迟执行的,而在Take<T>() 方法的下句已经执行了cache.clear() 清空了源数据,所有在foreach时候真正取数据的时候cache已经为空了,
Take<T>()自然就取不到数据了;
以下摘抄一点MSDN内容供大家参考;
那么,在上面这段示例代码中,如何修改使其得到正确结果呢,请看下面:
IList<int> cache = new List<int>();
int i = 0;
while (i < 1000)
{
cache.Add(i);
i++;
}
var temp = cache.Take(100).ToList();
cache.Clear();
foreach (var p in temp)
{
Console.WriteLine(p);
}
int i = 0;
while (i < 1000)
{
cache.Add(i);
i++;
}
var temp = cache.Take(100).ToList();
cache.Clear();
foreach (var p in temp)
{
Console.WriteLine(p);
}
很简单,将Take<T>() 的执行结果 ToXXX 一下就可以了,这里有ToList() ToArray() 等方法都是同样一个道理。
通过这个小例可以发现在使用Linq带来的便捷的同时,对于扩展方法也需小心使用。