2

我试图调用这些函数来摆脱我不需要的东西,但我的代码似乎在我开始认为是徒劳的斗争中打败了我。我尝试了多种方法来解决最后两个错误,但 IEnumerator 给了我通配符。错误在行:如果(枚举器2是IDisposable)和如果(枚举器是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”

4

2 回答 2

5

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

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

于 2011-06-04T02:53:09.037 回答
2

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

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

IEnumerator enumerator2 = null;
Match current = ...
于 2011-06-04T03:27:49.380 回答