假设我正在使用VB.Net中的一个小批量处理控制台应用程序.我希望能够像这样构建应用程序:
Sub WorkerMethod()
'Do some work
Trace.WriteLine("Work progress")
'Do more work
Trace.WriteLine("Another progress update")
'...
End Sub
Sub Main()
'Do any setup, like confirm the user wants to continue or whatever
WorkerMethod()
End Sub
请注意,我正在使用Trace
而不是Console
我的输出.这是因为可以从其他地方调用worker方法,或甚至生活在不同的程序集中,并且我希望能够为其附加不同的跟踪侦听器.那么如何将控制台连接到跟踪?
我已经可以通过定义一个简单的类(如下所示)并在Trace的侦听器集合中添加一个实例来实现它,但我想知道是否有更多接受或内置的方法来完成此任务:
Public Class ConsoleTrace
Inherits Diagnostics.TraceListener
Public Overloads Overrides Sub Write(ByVal message As String)
Console.Write(message)
End Sub
Public Overloads Overrides Sub WriteLine(ByVal message As String)
Console.WriteLine(message)
End Sub
End Class
harpo.. 156
您可以将以下内容添加到exe的.config文件中.
我也包含了TextWriter,以防您对登录文件感兴趣.
您可以将以下内容添加到exe的.config文件中.
我也包含了TextWriter,以防您对登录文件感兴趣.
乔尔,
你可以这样做,而不是应用程序配置方法:
Trace.Listeners.Add(new ConsoleTraceListener());
或者,如果您想在应用程序的生命周期中管理添加或删除侦听器:
ConsoleTraceListener listener = new ConsoleTraceListener(); Trace.Listeners.Add(listener); Trace.WriteLine("Howdy"); Trace.Listeners.Remove(listener); Trace.Close();
很好的解决方案,但我有一种情况,我有不同的DLL由同一个调用exe运行,所以我不想修改调用exe的.config文件.我希望每个dll都能处理它自己对跟踪输出的更改.
很容易:
Stream outResultsFile = File.Create ("output.txt"); var textListener = new TextWriterTraceListener (outResultsFile); Trace.Listeners.Add (textListener);
当然,这将输出Trace输出到"output.txt"文件.