将控制台输出镜像到文件

在C#控制台应用程序中,是否存在将控制台输出镜像到文本文件的明智方法?

目前,我只是将相同的字符串传递给两者Console.WriteLineInstanceOfStreamWriter.WriteLine以log方法传递。

回答:

这可能需要更多工作,但我会反其道而行之。

TraceListener为控制台实例化一个,为日志文件实例化一个;之后Trace.Write,请在代码中使用语句,而不要使用Console.Write。之后,删除日志或控制台输出或附加其他日志记录机制变得更加容易。

static void Main(string[] args)

{

Trace.Listeners.Clear();

TextWriterTraceListener twtl = new TextWriterTraceListener(Path.Combine(Path.GetTempPath(), AppDomain.CurrentDomain.FriendlyName));

twtl.Name = "TextLogger";

twtl.TraceOutputOptions = TraceOptions.ThreadId | TraceOptions.DateTime;

ConsoleTraceListener ctl = new ConsoleTraceListener(false);

ctl.TraceOutputOptions = TraceOptions.DateTime;

Trace.Listeners.Add(twtl);

Trace.Listeners.Add(ctl);

Trace.AutoFlush = true;

Trace.WriteLine("The first line to be in the logfile and on the console.");

}

据我所知,您可以在应用程序配置中定义侦听器,从而可以在不触摸构建的情况下激活或停用日志记录。

以上是 将控制台输出镜像到文件 的全部内容, 来源链接: utcz.com/qa/397725.html

回到顶部