75

假设我正在 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用于我的输出。这是因为工作方法可能从其他地方调用,甚至存在于不同的程序集中,我希望能够将不同的跟踪侦听器附加到它。那么如何将控制台连接到跟踪?

我已经可以通过定义一个简单的类(如下所示)并将一个实例添加到 Trace 的 listeners 集合中来做到这一点,但我想知道是否有更被接受或内置的方式来实现这一点:

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
4

3 回答 3

158

您可以将以下内容添加到您的 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,以防您有兴趣登录到文件。

于 2008-10-13T17:21:45.853 回答
56

乔尔,

您可以这样做而不是 app config 方法:

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

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

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

Trace.WriteLine("Howdy");

Trace.Listeners.Remove(listener);

Trace.Close();
于 2009-10-23T15:35:09.263 回答
11

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

很简单:

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

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

于 2009-05-14T14:59:16.337 回答