加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

C#Linq – 延迟执行

发布时间:2020-12-16 07:53:04 所属栏目:百科 来源:网络整理
导读:如果我建立一个查询说: (查询是使用System.Xml.Linq中的XDocument类生成的) var elements = from e in calendarDocument.Root.Elements("elementName") select e; 然后我调用elements.Last()几次.每个调用会返回最新的Last()元素吗? 例如,如果我这样做 ele
如果我建立一个查询说:

(查询是使用System.Xml.Linq中的XDocument类生成的)

var elements = from e in calendarDocument.Root.Elements("elementName") select e;

然后我调用elements.Last()几次.每个调用会返回最新的Last()元素吗?

例如,如果我这样做

elements.Last().AddAfterSelf(new XElement("elementName","someValue1"));
elements.Last().AddAfterSelf(new XElement("elementName","someValue2"));
elements.Last().AddAfterSelf(new XElement("elementName","someValue3"));
elements.Last().AddAfterSelf(new XElement("elementName","someValue4"));

它是否每次都获取最新的元素,并添加一个新的元素,或者是元素.

解决方法

是的,linq查询是懒惰的评估.直到你调用Last()才会执行查询.在这种情况下,它将每次获得最新的最新元素.

我认为这实际上是我第一次看到正确使用了几次调用Last()(或任何其他执行查询的操作符).当人们做到这一点时,通常会导致错误的表现.

我认为linq-to-xml库是足够智能的,以获得良好的性能为您的查询,但我不会相信它没有尝试.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读