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

假设我正在 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
36466 次浏览

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

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

很简单:

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

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

乔尔,

你可以用这个代替 app config 方法:

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

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

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


Trace.WriteLine("Howdy");


Trace.Listeners.Remove(listener);


Trace.Close();