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); //Nt wht y mght xpct
上面的代码是可以得到正确的结果,那么现在如果用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延时执行怎么理解”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341