是否有任何可以将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();
}
答案 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。净效应应与标准编码/行为相同。