背景 我正在尝试编写一个简单的SoapExtension类来记录来自asmx Web服务的入站/出站Soap消息。在this article on msdn之后,我已经能够开展工作了。但是,我真的很想了解它为什么/如何工作,而不仅仅是复制&粘贴代码。
问题: 我正在努力掌握的是在示例中处理IO流。我在Web上阅读的所有其他文章都以相同的方式处理流...首先获取对原始流的引用,创建内存中的“工作”流,然后根据需要交换内容。
第一个问题是,在这种情况下,“流链”是什么意思?我对流的理解是,写入任何流将自动写入管道中的“内部”流。如果是这种情况,为什么有必要手动将内容从一个流复制到另一个流?
第二个问题是,在示例复制方法中,他们每次创建一个StreamReader和StreamWriter而不处理它们 - 这是不是给GC带来了额外的压力?在高流量的Web服务上看起来不像你想要的东西......我尝试将两者都包含在使用语句中,但是处理读取器/写入器也关闭了流,这导致了更严重的错误。 .NET 4有新的Stream.CopyTo(Stream)方法,但对于.NET 3.5来说,更好的方法是什么?
答案 0 :(得分:3)
嗯,通过链接流,你可以基本上拥有不同的流,以链式顺序执行不同的操作。例如,您可以有一个压缩数据的流,然后是另一个加密数据的流(如果我们向另一个方向移动则相反)。
对于ChainStream本身,嗯......关于这个有很多话要说。我真的推荐这篇名为 Inside of Chainstream 的文章,这篇文章非常深入,也涵盖了您的大部分问题。
答案 1 :(得分:2)
链接在框架中完成。您获得原始流并返回放置修改结果的流。该框架将这个新流链接到任何其他扩展。
这是以这种方式实现的,因为链接工作“向后”。通常,您可以在流上添加新功能,但在这种情况下,您需要处理输入到原始流中的信息。
在线上调用close与Dispose相同。