1

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();
}
4

2 に答える 2

2

あなたは逆を行うことができます。標準のDebug/Trace呼び出しを使用し、ConsoleTraceListenerクラスを構成に追加します。正味の効果は、標準のコーディング/動作と同じである必要があります。

于 2012-12-13T17:30:30.367 に答える
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; }
    }
}

ステートメント内の whileへのすべてのConsole.WriteLine呼び出しをリダイレクトします。のすべての書き込みメソッドをオーバーライドするのはかなり面倒ですが、おそらくこの回答でラッパーを使用できますDebug.WriteLineusingTextWriter

于 2012-12-13T17:26:03.353 に答える