c# – 如何从方法返回一个Stream,知道它应该被处理?

我有一个方法,以FileStream为输入.此方法在for循环中运行.
private void UploadFile(FileStream fileStream)
{
    var stream = GetFileStream();
    // do things with stream
}

我有另一种创建和返回FileStream的方法

private FileStream GetFileStream()
{
    using(FileStream fileStream = File.Open(myFile,FileMode.Open))
    {
        //Do something
        return fileStream;
    }
}

现在,当我尝试访问返回的FileStream时,第一个方法抛出一个ObjectdisposedException,可能是因为我已经关闭了,因为我正在使用“using”来正确处理流.

如果我不使用“使用”,而是如下使用它,那么FileStream保持打开,循环的下一次迭代(在同一个文件上操作)会引发异常,告诉该文件已经在使用中:

private FileStream GetFileStream()
{
    FileStream fileStream = File.Open(myFile,FileMode.Open);
    //Do something
    return fileStream;
}

如果我使用try-finally块,那么我最后关闭流,那么它也会抛出ObjectdisposedException.

如何有效地返回文件流并关闭它?

解决方法

当您从方法返回Idisposable时,您将将其处理的责任归于您的主叫方.因此,您需要在流的整个使用情况下声明您的使用块,在您的情况下,您可能会跨越上传文件调用.
using (var s = GetFileStream())
    UploadFile(s);

相关文章

在要实现单例模式的类当中添加如下代码:实例化的时候:frmC...
1、如果制作圆角窗体,窗体先继承DOTNETBAR的:public parti...
根据网上资料,自己很粗略的实现了一个winform搜索提示,但是...
近期在做DSOFramer这个控件,打算自己弄一个自定义控件来封装...
今天玩了一把WMI,查询了一下电脑的硬件信息,感觉很多代码都...
最近在研究WinWordControl这个控件,因为上级要求在系统里,...