3

假设我想使用 2 个实现 IDispose 模式的类。其中一个类使用另一个类进行实例化,但之后不需要。当堆叠“使用”关键字时,这将导致(例如)在使用字体期间锁定文件。出于“编码美感”的原因,我希望在完成文件后立即解锁文件。

看看下面的“类标签”系统。

using1 (Stream stream = File.OpenRead("font.ttf"))
using2 (Font font = FontExtensions.FromStream(stream, 32))
ENDusing1
//use font here
ENDusing2

分层方式,代码块的设计方式,对当前的处理施加了(美)限制。当然,这可以通过使用 try/finally 块来解决,但这些并不那么整洁。

我是否缺少使用(lol?)嵌套 IDisposable 对象/流的基本设计?

请分享您对标记代码块的看法以及解决此问题的最佳方法(编码美)。

4

2 回答 2

9

您可以嵌套使用,同时关闭甚至提前处理流。

using (Stream stream = File.OpenRead("font.ttf")) {
    using (Font font = FontExtensions.FromStream(stream, 32)) {
        stream.Close(); // Or stream.Dispose();

        //use font here
    }
}

该类FileStream在内部使用一个标志来了解它是否已关闭或处置,并确保这种情况不会发生两次。该Dispose方法只是调用该Close方法。

于 2012-11-22T15:44:15.530 回答
2

您可以创建一个实用方法来从临时资源创建您的对象:

public static T FromTempResource<T, TDisp>(Func<TDisp> dispFunc, Func<TDisp, T> createFunc) where TDisp : IDisposable
{
    using(TDisp d = dispFunc())
    {
        return createFunc(d);
    }
}

你的例子可能是:

using (Font font = FromTempResource(() => File.OpenRead("font.tt"), stream => FontExtensions.FromStream(stream, 32))
{

}
于 2012-11-22T15:58:40.493 回答