将控制台输出镜像到文件
在C#控制台应用程序中,是否存在将控制台输出镜像到文本文件的明智方法?
目前,我只是将相同的字符串传递给两者Console.WriteLine
并InstanceOfStreamWriter.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