Linq延时执行

本文向大家介绍Linq延时执行,可能好多人还不了解Linq延时执行,没有关系,看完本文你肯定有不少收获,希望本文能教会你更多东西。

Linq的大多数查询运算符的一个重要特性就是,他们并不是在构建的时候就立即执行,而是在枚举是执行,换句话说,当枚举变量调用MoveNext时执行。

在构建查询之后,另外插入到列表中的数字也会包含在结构中,因为直到foreach运行时此才回进行筛选或者是排序操作,称之为延时执行或延缓计算,所有标准查询运算符均为延时执行,但是有的运算符不支持延时执行的机制,而是立即执行,如Count 、ToAarry、toLookup等。

Linq延时执行还有一点不好的影响,如果查询的lambda表达式引用了局部变量,那么这些便来那个会受到外部便来那个语义的约束。

当在foreach循环中构建查询时,这就会成为一个陷阱,例如假定想要删除字符串中的所有元音字母。如下所示的虽然效率不高,但是能得到正确的结果:

IEnumberable<int> qurey ="Not what you might expect"; 
queryquery =query.Where(c=>c!='a'); 
queryquery =query.Where(c=>c!='e');  
queryquery =query.Where(c=>c!='i');  
queryquery =query.Where(c=>c!='o');  
queryquery =query.Where(c=>c!='u');     
foreach(char c in query)  
{
  Console.Write(c);
}

上面的代码是可以得到正确的结果,那么现在如果用foreach循环重写这段代码能否的道正确的结果:

IEnumerable<char> query ="Not what you might expect";  foreach(cha vowel in "aeiou")  qwuer =query.Where(c=>c!=vowel);   foreach(char c in query)  Console.Write(c); //Not what yo might expect  //只删除了'u',这是因为编译器将foreach循环翻译成如下的代码:  IEnumerable<char> vowels="aeiou";  Iemuberator<char> rator=vowels.GetEnumerator();   char vowel;  while(rator.MoveNext())  {  vowel =rator.Current;  queryquery =query.Where(c=>c!=vowel);  } 

因为vowel变量时循环外部声明的,同一个变量重复声明更新,所以每个lambda表达式获取的是同样的vowel.之后枚举查询时,所有的lambda表达式引用了这个变量的当前值,即'u'。为了解决这个问题,必须将循环变量赋值被另一再循环代码块内声明的变量:

IEnumberable<int> qurey ="Not what you might expect";  foreach( char vowel in "aeiou")  {  char temp =vowel;  queryquery =query.Where(c=>c!=temp);  } 

这样每次循环迭代守使用新的变量,以上介绍Linq延时执行。

原文地址:https://www.cnblogs.com/kassSSB/p/4567178.html