C# Debug Trace调试类用法

    Debug和Trace都是调试类。

    Debug类的方法只有DEBUG版中生效,而Trace的方法可以在DEBUG/RELEASE版本中生效。

一、Debug类

Debug类的控制台输出及断言Assert用法。

  1. public static void TestDebug()
  2. {
  3.     Debug.Listeners.Add(new TextWriterTraceListener(Console.Out));
  4.     Debug.AutoFlush = true;
  5.     Debug.Indent();
  6.     Debug.WriteLine("Debug WriteLine()");
  7.     Console.WriteLine("Console.WriteLine()");
  8.     Debug.WriteLine("Debug WriteLine2()");
  9.     Debug.Unindent();
  10.       
  11.     /* Debug.Assert测试 */
  12.     int data = 0;
  13.     data--;
  14.     Debug.Assert(data > 0, "Debug.Assert: data小于0是不允许的!");
  15. }



image



二、Trace类

Trace类的控制台、LOG文件输出及断言Assert用法

  1. public static void TestTrace()
  2. {
  3.     /* 设置跟踪信息同时在控制台和日志文件中输出 */
  4.     Trace.Listeners.Add(new TextWriterTraceListener(Console.Out));
  5.     Trace.Listeners.Add(new TextWriterTraceListener("testtrace.log"));
  6.     Trace.AutoFlush = true;
  7.     /* Trace Indent and Unindent 通过缩进来区分WriteLine的输出 */
  8.     Trace.Indent();
  9.     Trace.WriteLine("Entering Main");
  10.     Console.WriteLine("Hello World.");
  11.     Trace.WriteLine("Exiting Main\n");
  12.     Trace.Unindent();
  13.     /* Trace.Assert测试 */
  14.     int data = 0;
  15.     data--;
  16.     Trace.Assert(data > 0, "Trace.Assert: data小于0是不允许的!");
  17. }


image



三、Trace类的五级信息输出用法

    由于Trace类可以在发布版本中起作用,所以,在做Trace输出信息的时候,可能有些信息是调试的时候需要,发布的时候又不需要了,那怎么才能保证信息不在发布的时候输出呢?.NET为我们提供了五个控制Trace的跟踪级别,使用它们不必重新编译,他们跟别是:

image

  1. public static void TestTraceWithSwitch()
  2. {
  3.     Trace.Listeners.Add(new TextWriterTraceListener(Console.Out));
  4.     TraceSwitch ts = new TraceSwitch("mySwitch", "in App.config file");
  5.     Trace.WriteLineIf(ts.TraceError, "Error!!!");
  6.     Trace.WriteLineIf(ts.TraceWarning, "Warning!!!");
  7.     Trace.WriteLineIf(ts.TraceInfo, "Info!!!");
  8.     Trace.WriteLineIf(ts.TraceVerbose, "Verbose!!!");
  9.     
  10.     Console.ReadKey();
  11. }

App.config文件

image


参考网址:

http://blog.csdn.net/yunhaic/article/details/4863322

https://msdn.microsoft.com/zh-cn/library/system.diagnostics.debug(v=vs.110).aspx

https://msdn.microsoft.com/zh-cn/library/zd83saa2(v=vs.100).aspx

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值