c# – 有没有办法使用动态创建目标的using语句?

前端之家收集整理的这篇文章主要介绍了c# – 有没有办法使用动态创建目标的using语句?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
假设我已经定义了一个MyDisposable类:IDisposable.我知道我可以在 using声明中提供一个硬编码的 IDisposable对象列表:
using (MyDisposable firstDisposable = new MyDisposable(),secondDisposable = new MyDisposable())
{
    // do something
}

现在假设我有几个方法对我的一次性对象集合执行操作,我想在using语句中执行此操作.它可能看起来像这样(但是这当然不起作用,因为using块需要一个或多个IDisposable对象并且我传递一个集合对象):

using (var myDisposables = GetMyDisposables())
{
    foreach (var myDisposable in myDisposables)
    {
        DoSomething(myDisposable);
        DoSomethingElse(myDisposable);
    }
}

为清楚起见,其他方法如下:

static List<MyDisposable> GetMyDisposables()
{
    throw new NotImplementedException(); // return a list of MyDisposable objects
}

static void DoSomething(MyDisposable withMyDisposable)
{
    // something
}

static void DoSomethingElse(MyDisposable withMyDisposable)
{
    // something else
}

有什么方法可以用using语句完成这个吗?或者我是否必须抛弃语句并手动处理?

解决方法

您可以采取的一种方法是创建IDisposable对象的集合,这也是IDisposable:
class CollectionOfDisposable<T> : IDisposable where T : IDisposable  {
    public IList<T> Members {get; private set;}
    public CollectionOfDisposable(IEnumerable<T> members) {
        Members = members.ToList();
    }
    public void Dispose() {
        var exceptions = new List<Exception>();
        foreach (var item in Members) {
            try {
                item.Dispose();
            } catch (Exception e) {
                exceptions.Add(e);
            }
        }
        if (exceptions.Count != 0) {
            throw new AggregateException(exceptions);
        }
    }
}

现在你可以这样写:

using (var myDisposables = GetMyDisposables()) {
    foreach (var myDisposable in myDisposables.Members) {
        DoSomething(myDisposable);
        DoSomethingElse(myDisposable);
    }
}

static CollectionOfDisposable<MyDisposable> GetMyDisposables() {
    throw new NotImplementedException(); // return a list of MyDisposable objects
}

猜你在找的C#相关文章