清理IDisposable问题

时间:2011-06-04 02:48:30

标签: c# regex idisposable ienumerator dispose

我试图把这些功能称为摆脱我不需要的东西,但我的代码似乎在我开始认为是徒劳的挣扎中击败了我。我已经尝试了多种方法来解决最后两个错误,但IEnumerator给了我外卡。错误在线:  if(enumerator2是IDisposable) 和  if(枚举器是IDisposable)

        try
        {
            enumerator = matchs.GetEnumerator();
            while (enumerator.MoveNext())
            {
                IEnumerator enumerator2;
                Match current = (Match) enumerator.Current;
                num = 0;
                try
                {
                    enumerator2 = current.Groups.GetEnumerator();
                    while (enumerator2.MoveNext())
                    {
                        Group group = (Group) enumerator2.Current;
                        strArray[num, num3] = group.Value;
                        num++;
                    }
                }
                finally
                {
                    if (enumerator2 is IDisposable)
                    {
                        (enumerator2 as IDisposable).Dispose();
                    }
                }
                if (num2 < num3)
                {
                    num2 = num3;
                }
                num3++;
            }
        }
        finally
        {
            if (enumerator is IDisposable)
            {
                (enumerator as IDisposable).Dispose();
            }
        }
        strArray[num, 0] = Conversions.ToString((int) (num2 + 1));
        return strArray;
    }

编辑 - 特定错误消息: 使用未分配的局部变量'enumerator2'
使用未分配的局部变量'enumerator'

2 个答案:

答案 0 :(得分:5)

使用for-each循环而不是while循环。如果需要,它会为你调用Dispose。

http://msdn.microsoft.com/en-us/library/aa288257(VS.71).aspx

答案 1 :(得分:1)

您应该使用其他人指出的foreach循环。

,您收到该错误的原因是因为enumerator2块中使用finally时,编译器无法知道它被设置为某个值(因为它可能不是在某些特殊情况下)。您可以按原样修复代码:

IEnumerator enumerator2 = null;
Match current = ...