【问题标题】:TraceSource from referenced library not logging when programmatically added以编程方式添加时引用库中的 TraceSource 未记录
【发布时间】:2013-11-08 23:38:18
【问题描述】:

这是我的 Winforms 应用程序中的配置文件。目前它已将 MyTraceSource 注释掉,如果我取消注释并运行我的程序,它会按预期工作。我从我引用的库中获得输出到我的控制台。 MyTraceSource 是一个 Trace 源,它在我的引用库中被实例化并使用,我将其称为 MyOposServiceObject。您会注意到我在我的 Logger.cs 文件中设置了另一个 TraceSource,名为 TestApplication。该跟踪源是我在测试应用程序中使用的日志记录(多么合乎逻辑的名称......)只是为了让我清楚在 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 什么也没得到。我做错了什么?

【问题讨论】:

  • 在你的 app.config 中,MyTraceSource 被注释掉了。可能就是这样。
  • @ZacharyYates 如果我取消注释,我的调试窗口中仍然一无所获,但我确实得到了控制台的输出。
  • 我的第一个猜测是 TraceListener 需要提供所有可覆盖的方法,TraceEvent 等(TraceInfo 除外,只有在您使用 TraceInfo 时才重要)
  • 您可能需要在您的TraceSource 中指定SourceLevels,尝试:new TraceSource("MyTraceSource", SourceLevels.All);
  • @ZacharyYates 我试过 SourceLevels.All 并没有改变。

标签: c# tracesource


【解决方案1】:

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

我假设你的应用结构是这样的:

- 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.");
}

【讨论】:

  • 问题不在于单个项目中的侦听器,我可以使多个跟踪源在单个项目中工作。问题在于以编程方式使用多个项目的跟踪源
  • @RobertSnyder 你能再解释一下情况吗?你有定义TraceSource 的类库和另一个使用它的项目吗?
  • 查看编辑后的帖子。主要变化在开头段落。一言以蔽之,是的。
猜你喜欢
  • 2011-08-01
  • 2014-07-20
  • 1970-01-01
  • 2011-06-16
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多