足迹

能看不尽景,始是不凡人

 

VC中TRACE(转载)

 

  注:最近编MFC程序,需要输出调试信息。网上搜了一下,据说TRACE宏可以提供在DEBUG程序中“插桩”的功能,但在并不包含在RELEASE程序中的能力。就学了一下,用了一下感觉不错。

 

下面的文章转载自CSDN,不错,呵呵。 网址为:http://blog.csdn.net/yangsen2016/archive/2007/06/04/1636996.aspx

感谢作者啦。 

 

TRACE宏对于VC下程序调试来说是很有用的东西,有着类似printf的功能;该宏仅仅在程序的DEBUG版本中出现,当RELEASE的时候该宏就完全消失了,从而帮助你调试也在RELEASE的时候减少代码量。

  使用非常简单,格式如下:

TRACE("DDDDDDDDDDD");

TRACE("wewe%d",333);

  同样还存在TRACE0,TRACE1,TRACE2...分别对应0,1,2...个参数

  TRACE信息输出到VC IDE环境的输出窗口(该窗口是你编译项目出错提示的那个窗口),但仅限于你在VC中运行你的DEBUG版本的程序。

  TRACE信息还可以使用DEBUGVIEW来捕获到。这种情况下,你不能在VC的IDE环境中运行你的程序,而将BUILD好的DEBUG版本的程序单独运行,这个时候可以在DEBUGVIEW的窗口看到DEBUGVIE格式的输出了。

VC中TRACE的用法有以下四种:

1:

  TRACE  ,就是不带动态参数输出字符串,   类似C的printf("输出字符串"); 
   
2:

    TRACE   中的字符串可以带一个参数输出  , 类似C的printf("...%d",变量);    
   
3:

   TRACE   可以带两个参数输出,类似C的printf("...%d...%f",变量1,变量2);    
   
4:

   TRACE   可以带三个参数输出,类似C的printf("...%d,%d,%d",变量1,变量2,变量3);

  TRACE 宏有点象我们以前在C语言中用的Printf函数,使程序在运行过程中输出一些调试信息,使我们能了解程序的一些状态。但有一点不同的是:


  TRACE 宏只有在调试状态下才有所输出,而以前用的Printf 函数在任何情况下都有输出。和Printf 函数一样,TRACE函数可以接受多个参数如:

  int x = 1;
  int y = 16;
  float z = 32.0;
  TRACE( "This is a TRACE statement\n" );
  TRACE( "The value of x is %d\n", x );
  TRACE( "x = %d and y = %d\n", x, y );
  TRACE( "x = %d and y = %x and z = %f\n", x, y, z );

  要注意的是TRACE宏只对Debug 版本的工程产生作用,在Release 版本的工程中,TRACE宏将被忽略。

附加资源:

  debugview的下载地址: http://www.onlinedown.net/soft/62573.htm

 

 

posted on 2009-04-13 16:33  姚伟峰  阅读(583)  评论(0)    收藏  举报

导航