我的调试跟踪函数_TRACE

本文介绍了一个用于C++编程的调试宏实现方法,该宏能够将变量名及值输出到调试环境中,便于开发者定位问题。通过具体示例展示了如何使用此宏进行变量值的输出。
#include <comdef.h>
#ifdef _DEBUG
  void _TRACE( LPCTSTR szInfo, _variant_t Val)
  {
    try
    {
      WCHAR szBuff[1024];
      memset(szBuff, 0, sizeof(szBuff));

      if(szInfo)
      {
        _variant_t vs( szInfo );
        vs.ChangeType( VT_BSTR );
        wcscat(szBuff, vs.bstrVal);

        if(wcslen(szBuff) > 0)
          wcscat(szBuff, L"=> " );
      }

      Val.ChangeType(VT_BSTR);
      wcscat(szBuff, Val.bstrVal);

      if(wcslen(szBuff) > 0)
        wcscat(szBuff, L"/r/n" );
      OutputDebugStringW(szBuff);
    }
    catch (_com_error &e)
    {
      AfxMessageBox(e.ErrorMessage());
    }
  }

  #define __TRACE(Val) /
  { /
    TCHAR szInfo[1024];/
    memset( szInfo, 0 , sizeof(szInfo));/
    wsprintf( szInfo, _T("%s(%d): %s"),__FILE__, __LINE__, #Val);/
    _TRACE( szInfo, Val);/
  }

#else
  #ifdef __noop
    #define _TRACE(x,y) __noop
    #define __TRACE(Val) __noop
  #else
    #define _TRACE(x,y) //
    #define __TRACE(Val) //
  #endif
#endif

 

//简单的测试代码
  double Val = 8.54;
  _TRACE( _T("Test"), Val);
  _TRACE( _T("String"), _T("ABCD"));

  __TRACE( Val );

 

输出

Test=> 8.54
String=> ABCD

C:/TEMP/ff/ff.cpp(106): Val=> 8.54

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值