gpt4 book ai didi

c# - 以编程方式添加时,引用库中的 TraceSource 不记录

转载 作者:太空宇宙 更新时间:2023-11-03 16:05:32 27 4
gpt4 key购买 nike

这是我的 Winforms 应用程序的配置文件。目前它已将 MyTraceSource 注释掉,如果我取消注释并运行我的程序,它会按预期工作。我从我引用的库中获取输出到我的控制台。 MyTraceSource 是一个 Trace 源,它在我将调用 MyOposServiceObject 的引用库中实例化和使用。您会注意到我在名为 TestApplication 的 Logger.cs 文件中设置了另一个 TraceSource。该跟踪源是我在测试应用程序中使用的日志记录(多么合乎逻辑的名称......)只是为了让我清楚在 2 个不同的项目中实例化和使用了 2 个跟踪源。一个是类库,一个是winforms应用。如果我将我的 winforms 应用程序编译为控制台程序并在 app.config 文件中取消注释我的 TraceSource,我会从 MyOposServiceObject 记录到控制台。清澈如泥???确定一些代码。

App.config

<system.diagnostics>
<trace autoflush="true"/>
<sharedListeners>
<!-- Outputs to a Log File-->
<add name ="file" type ="System.Diagnostics.TextWriterTraceListener" initializeData="DEMO.log">
<filter type="System.Diagnostics.EventTypeFilter" initializeData="Off"/>
</add>
<!-- Outputs to the console-->
<add name="console" type ="System.Diagnostics.ConsoleTraceListener" >
<filter type="System.Diagnostics.EventTypeFilter" initializeData="All"/>
</add>
</sharedListeners>
<sources>
<!--<source name="MyTraceSource" switchValue="All" >
<listeners>
<remove name="Default"/>
<add name="console"/>
</listeners>
</source>-->
</sources>
</system.diagnostics>

但是,我不想让我的程序成为控制台程序,所以我制作了一个自定义的 TraceListener。

MyTraceListener.cs

public class MyTraceListener : TraceListener
{
private System.Windows.Forms.TextBox output;
public MyTraceListener(System.Windows.Forms.TextBox output)
{
this.Name = "FancyTrace";
this.output = output;
}
public override void Write(string message)
{
output.SafeSetText(string.Format("{0}\r\n[{1}] {2}",output.Text, DateTime.Now.ToString("F"), message));
}

public override void WriteLine(string message)
{
Write(message + Environment.NewLine);
}
}

我是这样装的

Logger.cs

    internal static void ShowDebugWindow()
{
if (debugWindow != null) return;

debugWindow = new Form();
debugWindow.TopMost = true;
debugWindow.FormBorderStyle = FormBorderStyle.FixedToolWindow;
TextBox tb = new TextBox();
tb.Multiline = true;

tb.Dock = DockStyle.Fill;
debugWindow.Controls.Add(tb);
MyTraceListener myTrace = new MyTraceListener(tb);
trace.Listeners.Add(myTrace);
opos.Listeners.Add(myTrace);
debugWindow.Show();
}
private static TraceSource trace = new TraceSource("TestApplication");
private static TraceSource opos = new TraceSource("MyTraceSource");

现在 trace 被用在这个应用程序中,它的输出确实进入了我的小调试窗口。但我没有从 opos 那里得到任何东西。我做错了什么?

最佳答案

总而言之,您希望两个项目中的所有 TraceSource 都显示在您的小调试窗口、控制台和任何共享监听器中,对吗?

我假设您的应用程序结构如下:

- Solution
- Class Library
- MyTraceListener.cs
- Logger.cs
- OtherCodeThatUsesLogger.cs
- Winforms Project : References Class Library
- app.config
- WinformsCodeThatUsesLogger.cs

如果是这样,我认为这里的问题是您的消费代码没有使用您在 Logger.cs 中创建的 TraceSource 实例。

Logger.cs

public static TraceSource trace = new TraceSource("TestApplication");
public static TraceSource opos = new TraceSource("MyTraceSource");

消费代码

void foo() {
Logger.trace.TraceInformation("hello... ");
Logger.opos.TraceInformation("muggles.");
}

关于c# - 以编程方式添加时,引用库中的 TraceSource 不记录,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19664606/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com