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 );

也可以使用OutputDebugString来调试。

VC调试信息输出 TRACE宏相关推荐

  1. wince 串口调试信息输出

    不管在WinCE5.0还是在WinCE6.0中,我们在调试驱动或者应用的时候都会用到打印函数.在驱动里面,我们可能会用DEBUGMSG(..),RETAILMSG(..),还有NKDbgPrintfW ...

  2. Qt on Android:将Qt调试信息输出到logcat中

    版权全部 foruok .如需转载敬请注明出处(http://blog.csdn.net/foruok). 假设你在目标 Android 设备上执行了 Qt on Android 应用,你可能希望看到 ...

  3. qt在GUI显示时,将调试信息输出到控制台的设置

    1. 在.pro文件中添加一下设置: CONFIG += console 2. 项目的[构建和运行]中,需要勾选[Run in terminal]: 转载于:https://www.cnblogs.c ...

  4. 巧用可变参数宏、编译器内置宏和printf输出调试信息

    前言: 我们在写程序的时候,总是或多或少会加入一些printf之类的语句用于输出调试信息,但是printf语句有个很不方便的地方就是当我们需要发布程序的时候要一条一条的把这些语句删除,而一旦需要再次调 ...

  5. 利用编译器宏完美的输出调试信息

    前言: 我们在写程序的时候,总是或多或少会加入一些printf之类的语句用于输出调试信息,但是printf语句有个很不方便的地方就是当我们需要发布程序的时候要一条一条的把这些语句删除,而一旦需要再次调 ...

  6. OutputDebugString输出调试信息

    OutputDebugString输出调试信息 声明 <windows.h>文件声明了 OutputDebugString() 函数的两个版本:一个用于 ASCII,一个用于 Unicod ...

  7. 使用OutputDebugString输出调试信息

    概要: 在编写控制台程序的时候我们经常会使用printf输出调试信息,使我们了解程序的状态,方便调试,但是当编写非控制台程序的时候这种方法就行不通了.可以使用以下方法: (1)使用Log机制 (2)用 ...

  8. linux命令 重定向%3e,linux输出信息调试信息重定向

    在运行linux的时候有所有的调试信息可以分为三个部分 1.bootloader输出信息 U-Boot 1.3.2(Nov 19 2016 - 22:02:08) DRAM: 64 MB Flash: ...

  9. C++ 自定义调试信息的输出

    自定义调试信息的输出 调试信息的输出方法有很多种,  例如直接用printf,  或者出错时使用perror, fprintf等将信息直接打印到终端上, 在Qt上面一般使用qDebug,而守护进程则一 ...

最新文章

  1. ksql中定义的本体在dataModel中不存在
  2. 国外开源威胁情报feed站点 简介
  3. 版本管理工具 (git 或者 svn)
  4. 对DataTable里数据进行排序
  5. javascript --- 使用ajax与服务器进行通信
  6. REVERSE-PRACTICE-CTFSHOW-2
  7. IaaS, PaaS和SaaS及其区别
  8. nsx很可爱的公众号 vSAN 文章合集
  9. 【图像去噪】基于matlab GUI均值+中值+高斯低通+多种小波变换图像去噪【含Matlab源码 856期】
  10. python3.6 numpy下载_numpy下载安装 NumPy MKL v1.13.1 cp36 for Python3.6 官方安装版 64位 下载-脚本之家...
  11. 联想计算机BIOS密码忘记了,联想笔记本CMOS(BIOS)密码清除
  12. matlab-基础 plot linewidth 设置图像的线粗细
  13. Uclinux、Linux区别
  14. 京东网页端顶部导航HTML代码
  15. 女程序员在互联网界到底有没有被歧视?
  16. 旅行青蛙服务器维护时间,旅行青蛙怎么调节时间 旅行青蛙修改时间攻略
  17. Tita绩效宝:在360度评估中要问的10个最佳问题
  18. visual studio编译报错“常量中有换行符”等字符串中的错误
  19. zsh : corrupt history file ~/.zsh_history
  20. c语言中文拼音排序,为sqlite增加汉字拼音排序功能

热门文章

  1. MyBatis代码生成器-Example讲解
  2. Spring Boot中使用MongoDB数据库
  3. 3._FILE_和_LINE_
  4. Android --- log.e(),log.d(),log.i()等的区别
  5. Java 洛谷 P2141 珠心算测验
  6. python总线 rabbitmq_Python rabbitMQ如何实现生产消费者模式
  7. react router 级联路由_前端路由原理解析和实现
  8. 字典删除多个键值对方法_Life is short,you need Python——Python序列(元组、字典、集合)...
  9. matlab复数方程组,【求解】matlab求解非齐次方程组,但是系数矩阵是复数,求帮忙...
  10. 数据中心机房应该如何布线,机柜布线方法详解!