将跟踪输出重定向到控制台

时间:2008-10-13 17:19:31

标签: .net vb.net .net-2.0 console trace

假设我正在使用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

3 个答案:

答案 0 :(得分:149)

您可以将以下内容添加到exe的.config文件中。

<?xml version="1.0"?>
<configuration>
    <system.diagnostics>
        <trace autoflush="true">
            <listeners>
                <add name="logListener" type="System.Diagnostics.TextWriterTraceListener" initializeData="cat.log" />
                <add name="consoleListener" type="System.Diagnostics.ConsoleTraceListener"/>
            </listeners>
        </trace>
    </system.diagnostics>
</configuration>

我也包含了TextWriter,以防您对登录文件感兴趣。

答案 1 :(得分:50)

乔尔,

您可以执行此操作而不是应用配置方法:

Trace.Listeners.Add(new ConsoleTraceListener());

或者,如果你想在应用程序的生命周期中管理添加或删除监听器:

ConsoleTraceListener listener = new ConsoleTraceListener();
Trace.Listeners.Add(listener);

Trace.WriteLine("Howdy");

Trace.Listeners.Remove(listener);

Trace.Close();

答案 2 :(得分:11)

很好的解决方案,但我有一种情况,我有不同的dll由同一个调用exe运行,所以我不想修改调用exe的.config文件。我希望每个dll都能处理它自己对跟踪输出的更改。

足够简单:

Stream outResultsFile = File.Create ("output.txt");
var textListener = new TextWriterTraceListener (outResultsFile);
Trace.Listeners.Add (textListener);

当然,这会将Trace输出输出到“output.txt”文件。