调试 TRACE(MFC)

本文详细介绍了MFC中用于调试的TRACE宏及其变体,包括TRACE0、TRACE1、TRACE2和TRACE3等宏的使用方法及注意事项。通过具体步骤指导如何在MFC应用程序中启用并查看TRACE输出。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

参考:http://wenku.baidu.com/view/f5e105db50e2524de4187e04.html

TRACE    

TRACE(exp)    

说明:    把一个格式化字符串送到转储设备,

例如,文件或调试监视器,而提供与printf相似的功能。

同MS_DOS下C程序的printf一样,TRACE宏是一个在程序运行时跟踪变量值的方便形式。

在DEBUG环境中,TRACE宏输出到afxDump。在Release版中他不做任何工作。    

 注释: 此宏只在此宏只在此宏只在此宏只在MFC的的的的DEBUG版中有效版中有效版中有效版中有效。    

TRACE0    

TRACE0(exp)    

 说明:    与TRACE相似,但他把跟踪字符串放在代码段中,而不是DGROUP,因此使用少的DGROUP空间。

TRACE0是一组跟踪宏的一个变体,这些宏可用于调试输出。这一组包括TRACE0,TRACE1,TRACE2和TRACE3,这些宏不同在于所取参数的数目不同。TRACE0只取一个格式化字符串并可用于简单文本消息只取一个格式化字符串并可用于简单文本消息只取一个格式化字符串并可用于简单文本消息只取一个格式化字符串并可用于简单文本消息。。。。

TRACE1取一格式化字符串加上一个变量取一格式化字符串加上一个变量取一格式化字符串加上一个变量取一格式化字符串加上一个变量——一个将转储的变量一个将转储的变量一个将转储的变量一个将转储的变量。。。。同样同样同样同样,,,,

TRACE2,TRACE3分别取分别取分别取分别取2个个个个或或或或3个参数个参数个参数个参数((((在格式化字在格式化字在格式化字在格式化字符串之后符串之后符串之后符串之后)。)。)。)。如果用户以便以了应用程序的发行版,那么它只把数据转储到afxDump。    

注释: 此宏只在MFC的DEBUG中有效。

 

TRACE1     TRACE1(exp,param1) (一个表达式加上一个参数) 

TRACE2     TRACE2(exp,param1,param2)    

TRACE3     TRACE3(exp,param1,param2,param3)   

 

总结用法如下:

1.在MFC中加入TRACE语句

2.在TOOLS->MFC TRACER中选择 “ENABLE TRACING”点击OK

3.进行调试运行,GO(F5)(特别注意:不是执行‘!’以前之所以不能看到TRACE内容,是因为不是调试执行,而是‘!’了,切记,切记)

4.然后就会在OUTPUT中的DEBUG窗口中看到TRACE内容了,调试执行会自动从BUILD窗口跳到DEBUG窗口,在那里就看到TRACE的内容了 

 

()功能: 输出调试变量(类似于TRACE) ()特点: 1.可以自动适应参数的类型(最主要依赖于ostringstream) 2.可以自动适应输入参数的个数。(关闭了编译提醒 #pragma warning(disable: 4003) ) 3.会在输出的变量值前面自动添加变量的名称,方便查看 4.程序创建Edit窗口用于输出转换后的字符串。 5.程序退出时会将输出字符串保存到工程目录下的DebugData.txt。方便查看 6.多种编译模式,比如可让DEBUG和Release版本都能输出调试变量或者两者都不输出 7.支持UNICODE,WIN32,Dll,MFC ()使用说明: 1.把trace.h复制到工程目录下(可以不添加到工程)。 2.在文件"stdafx.h"里(文件的下方)添加 #include "trace.h"。之后就可以使用trace()宏了。 3.所有输出的字符串会保存在工程目录下的"DebugData.txt"文件,以方便查看 4.我把所有代码都放在一个头文件里,虽然不合符规范,但这样使用起来很方便。 5.trace(x,y,z,w)宏原本有4个参数,当参数不如时,编译器会给出警告,所以我使用 #pragma warning(disable: 4003) 把这个编译警告给关掉了。 ()可以使用的宏: trace(X,Y,Z,W) //输出常用类型变量,如int、double、short、POINT、RECT、string //且自动适应变量的个数(变量数为1-4个) tracef() //格式化字符串,类似sprintf traceLastError()//输出系统错误代码,调用了GetLastError() traceRel(X,Y) //当X=true,输出"Y: successful" ; x=false,输出"Y: failed" traceClear() //清空窗口 ()关于trace宏使能设置: 1.默认情况下 NO_TRACE_WINDOW 和 TRACE_WINDOW都没定义,则 DEBUG版本会输出调试字符串,而Release版本不会 2.如果开头定义了#define NO_TRACE_WINDOW DEBUG版本和Release版本都不会输出输出调试字符串 3.如果开头定义了#define TRACE_WINDOW DEBUG版本和Release版本都会输出输出调试字符串 4.每次修改上面2个宏后需要全部重新编译才会生效
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值