MemoryStream mstr = new MemoryStream();using(StreamWriter w = new StreamWriter(mstr)) { ....}
由于处理StreamWriter还应该处理/关闭底层流,没有必要这样做?:
using(MemoryStream mstr = new MemoryStream())using(StreamWriter w = new StreamWriter(mstr)) { ....}
(注意这些只是示例,关于如何处理包装的流,而不是寻找像使用StringWriter等的替代方案)
解决方法 我的经验法则:如果它实现了Idisposable,请将其丢弃.虽然当前(可能永远),调用StreamWriter.dispose()关闭底层流,但您将来可能使用的其他流派生类可能不会.此外,它似乎也没有实际调用dispose(),因此非MemoryStreams可能无法正确处理(尽管我现在无法想到任何会受到影响的东西).
因此,虽然您可以安全地只处理StreamWriter,但我发现在可能的情况下始终使用块用于一次性用品是一种更好的做法.
总结以上是内存溢出为你收集整理的c# – using()并使用多个包裹的流进行处理全部内容,希望文章能够帮你解决c# – using()并使用多个包裹的流进行处理所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)