C#LINQ通过IEnumerable扩展方法进行调试

时间:2012-10-30 13:20:45

标签: c# linq debugging

我试图通过我称为DumpIt的以下IEnumerable扩展方法。调试器不会单步执行它。如何让调试器进入此扩展方法?

我的单元测试:

[Test]
        public void TestDumpIt()
        {
            var words =
                new string[] {"   KOOKABURRA", "Frogmouth", "kingfisher   ", "loon", "merganser"};

            var result = words
                .DumpIt(d => "original: " + d)
                .Select(word => word.Trim())
                .DumpIt(d => "trimmed: " + d)
                .Select(word => word.ToLower())
                .DumpIt(d => "lower cased: " + d)
                .Where(word => word.StartsWith("k"))
                .DumpIt(d => "starts with k: " + d)
                .OrderBy(word => word)
                .DumpIt(d => "orderd: " + d);
        }

扩展方法:

public static IEnumerable<T> DumpIt<T>(this IEnumerable<T> input,
    Func<T, string> toString
    )
{
    foreach (var item in input)
    {
        Output.ActivePane.Activate();
        Output.ActivePane.OutputString(
            ShowWhiteSpace ? '[' + toString(item) + ']' : toString(item));

        yield return item;
    }
}

感谢您的帮助!

1 个答案:

答案 0 :(得分:9)

使用yield时,您正在使用延迟执行。您正在使用的其他LINQ方法也使用延迟执行。在您开始枚举result中的TestDumpIt之前,DumpIt方法实际上不会被调用。如果要查看代码被调用,则需要枚举可枚举代码。例如,您可以在末尾添加result.ToList()以强制枚举。