5

编译器抱怨resultingThing在分配给之前正在使用下面的代码。

private IEnumerable<IThing> FindThings(dynamic spec)
{
    if (spec == null)
        yield break;

    IThing resultingThing;
    if (spec.Something > 0 && dictionary.TryGetValue(spec.Something, out resultingThing))
        yield return resultingThing;
    else
        // ...
}

为什么它声称这一点?

我尝试了一个不同版本的方法,其中没有yield用法(例如 just return IEnumerable<IThing>)但使用dynamic参数,我尝试了一个没有传入dynamic的方法版本(即我们在C# 的早期版本)。这些编译。

4

1 回答 1

1

我似乎是一个编译器错误(或限制,如果您愿意的话)。

我将最小的失败案例减少到:

static private IThing FindThings(dynamic spec)
{
    IThing resultingThing;
    if ((null!=spec) && dictionary.TryGetValue(spec, out resultingThing))
        return resultingThing;
return null;
}

它提供了相同的编译器诊断,不涉及动态成员查找,也不涉及迭代器块。

作为参考,单声道编译器不会绊倒:

using System;
using System.Collections.Generic;

public static class X
{
    public interface IThing { }

    private static readonly IDictionary<string, IThing> dictionary = new Dictionary<string, IThing>();

    static private IThing FindThings(dynamic spec)
    {
        IThing resultingThing;
        if ((null!=spec) && dictionary.TryGetValue(spec, out resultingThing))
            return resultingThing;
        return null;
    }

    public static void Main(string[] s)
    {

    }
}

编译:

dmcs -v -warnaserror -warn:4 t.cs

没有警告

于 2011-05-18T22:34:27.740 回答