随笔 - 24  文章 - 0 评论 - 19 阅读 - 41681
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

XPO使用了标准的System.Diagnostics的Trace Log机制,只需要在config文件中加入如下代码,即可在Debug时在输出窗口看到XPO生成的SQL语句。

复制代码
Config
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
    
<system.diagnostics>
        
<switches>
            
<add name="XPO" value="3" />
        
</switches>
    
</system.diagnostics>
</configuration>
复制代码

 

 

也可以将其记录到日志文件:

复制代码
Config
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
    
<system.diagnostics>
        
<trace autoflush="true" indentsize="4">
            
<listeners>
                
<add name="LogFileTraceListener" type="System.Diagnostics.TextWriterTraceListener" 
                    initializeData
="trace.log" />
                
<remove name="Default" />
            
</listeners>
        
</trace>
        
<switches>
            
<add name="XPO" value="3" />
        
</switches>
    
</system.diagnostics>
</configuration>
复制代码

 

 

因为采用.NET标准的Trace Log机制,我们也可以自己实现一个Log类:

复制代码
MyTraceListener
using System;

namespace Test
{
    
public class MyTraceListener: System.Diagnostics.TraceListener
    {
        
public MyTraceListener()
        {
            
        }
        
public MyTraceListener(string name)
            : 
base(name)
        {
            
        }

        
public override void Write(string message)
        {
            
throw new NotImplementedException();
        }

        
public override void WriteLine(string message)
        {
            
throw new NotImplementedException();
        }
    }
}
复制代码

 

然后在Config文件中做配置 :

复制代码
Config
 <system.diagnostics>
    
<trace autoflush="true" indentsize="4">
      
<listeners>
        
<!--注意命名空间和类名别写错-->
        
<add name="MyTraceListener" type="Test.MyTraceListener,Test"/>
        
<remove name="Default" />
      
</listeners>
    
</trace>
    
<switches>
      
<add name="XPO" value="3" />
    
</switches>
  
</system.diagnostics>
复制代码

 

或者在程序的入口点加上:

// Remove the original default trace listener.
Trace.Listeners.RemoveAt(0);

// Create and add a new MyTraceListener.
Trace.Listeners.Add(new MyTraceListener());

 

 

这样Log内容想记哪儿都可以随自己喜欢了,MyTraceListener的具体实现就不展开了。 

 

MSDN: TraceListener 类 

posted on   Elvin Chen  阅读(938)  评论(0编辑  收藏  举报
编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· [AI/GPT/综述] AI Agent的设计模式综述
点击右上角即可分享
微信分享提示