是否有System.Diagnostics.Debug类的TextWriter接口,用于Console.SetOut?

时间:2012-12-13 17:12:39

标签: c# console-application stdout output-window

是否有任何可以将Console.WriteLine调用重定向到System.Diagnostic.Debug-calls的内置内容?

我希望有这样的事情:

public static void CallNastyConsoleWriteLineUsingFunction() {
    Console.WriteLine(GetImportantInformation());
}

[...]

var writer = DebugTextWriter();
TextWriter stdout = Console.Out;
try
{
    Console.SetOut(writer);
    CallNastyConsoleWriteLineUsingFunction();
}
finally
{
    Console.SetOut(stdout);
}

或者甚至可能:

using(new ConsoleToDebugRedirector())
{
    CallNastyConsoleWriteLineUsingFunction();
}

2 个答案:

答案 0 :(得分:2)

你可以这样做:

public class Program
{
    public static void Main(string[] args)
    {
        using (new ConsoleRedirect<DebugTextWriter>())
        {
            Console.WriteLine("Testing testing...");
        }

        Console.WriteLine("Testing testing 2...");
        Console.ReadLine();
    }
}

public class ConsoleRedirect<T> : IDisposable
    where T : TextWriter, new()
{
    private readonly TextWriter _tmpTextWriter;

    public ConsoleRedirect()
    {
        _tmpTextWriter = Console.Out;
        Console.SetOut(new T());
    }

    public void Dispose()
    {
        Console.SetOut(_tmpTextWriter);
    }
}

public class DebugTextWriter : TextWriter
{
    public override void WriteLine(string value)
    {
        Debug.WriteLine(value);
    }

    public override void WriteLine(object value)
    {
        Debug.WriteLine(value);
    }

    public override void WriteLine(string format, params object[] arg)
    {
        Debug.WriteLine(format, arg);
    }

    public override Encoding Encoding
    {
        get { return Encoding.UTF8; }
    }
}

它会在Console.WriteLine语句中将所有Debug.WriteLine次调用重定向到using。覆盖TextWriter的所有写入方法非常麻烦,但您可以使用this answer中的包装器

答案 1 :(得分:2)

你可以反过来。使用标准的调试/跟踪调用并在配置中添加ConsoleTraceListener Class。净效应应与标准编码/行为相同。