【问题标题】:Do LINQ IEnumerable extensions call Dispose on their IEnumerable?LINQ IEnumerable 扩展是否在其 IEnumerable 上调用 Dispose?
【发布时间】:2015-08-11 01:07:28
【问题描述】:

鉴于我编写了一个实现IEnumerable 的类,并返回一个IEnumerator,这不仅仅是IDisposable 作为枚举器的性质,而是在完成后拥有它需要的托管资源Dispose()枚举时,只要我的枚举器在其 IDisposable 实现中正确处置这些托管资源,我是否可以相信以下内容将 Dispose() 那些托管资源?

return (new MyClass()).Select(x => x);

编辑:这个问题似乎与标记相似的一个 mods 相似,但它在语义上是不同的 IMO(我在提出问题之前就看到了)

【问题讨论】:

  • 你不需要像 John Skeet 的回复那样处理 ....[Link][1] [1]: stackoverflow.com/questions/13459447/…
  • 如果你想确定,你总是可以在你的Dispose() 中添加一个Console.WriteLine(),看看它是否会被解雇。
  • 如果他的MyClass 实现IDisposableDispose() 方法将被调用。垃圾收集器不是调用 Dispose() 的那个。
  • @MattRowland - MyClass 不正确。在 OP 的代码中,.Dispose 不会new MyClass() 上调用。
  • 我不是说它会。我是说他可以通过在Dispose() 方法中放置一个Console.WriteLine() 来检查它是否会。

标签: c# .net linq


【解决方案1】:

是的,您可以从 LINQ 的方法中依赖对迭代器的 Dispose() 调用。

在微软发布的reference code中,迭代器的使用分为三类:

  • foreach 循环中使用迭代器,确保调用 Dispose(),或
  • 迭代器与while 循环结合使用;这些迭代器是显式处理的
  • 迭代器在 using 块内获得,可确保自动处理。

在所有这些情况下,库确保迭代器的 Dispose() 方法在完成时被调用。

【讨论】:

  • 所以只有foreach的情况下会自动调用'on enumeration'?
  • @user2864740 是的。如果您从forwhile 内部手动使用Iterator<T>,您应该自己调用Dispose()
猜你喜欢
  • 1970-01-01
  • 2019-03-17
  • 2011-04-13
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2011-08-07
  • 2012-01-16
相关资源
最近更新 更多