网站首页 > 物联资讯 > 技术分享

在非MFC程序中使用调试宏 ASSERT(),VERIFY()和 TRACE()

2016-09-28 00:00:00 广州睿丰德信息科技有限公司 阅读
睿丰德科技 专注RFID识别技术和条码识别技术与管理软件的集成项目。质量追溯系统、MES系统、金蝶与条码系统对接、用友与条码系统对接

游戏制作已经开始采用C++了,却鲜有人选择使用MFC。但笔者觉得的 ASSERT(),VERIFY()和 TRACE()这几个宏很好用。所以就想自己写一个版本来适应Windows平台下不同的工程类型。

提醒:

  • ASSERT()被测试它的参数,若参数为0,则中断执行并打印一段说明消息。在 Release 版本的程序中它不起任何作用。
  • VERIFY()和 ASSERT()很相似,区别在于在 Release 版本中它仍然有效(译者注:原作者在这里没有讲清楚,VERIFY()不会打印说明,只是会对参数表达式求值)。
  • ASSERT()使用的时候必须保证参数表达式中不能有函数调用(译者注:ASSERT()宏在 Release 版本中不对表达式求值),因此对于任何有函数调用的参数表达式,应该使用宏 VERIFY(),以保证表达式中的函数调用在 Release 版本中会被正确求值。
  • TRACE()基本上就是函数 printf()的一个复制品,唯一的区别是它把结果输出到调试窗口。在 Release 版本中,它也是无效的。
  • 这三个宏在 Release 版本中都不会产生任何实质性的影响,它们是否起作用取决于是否定义了预定义了宏 _DEBUG。这是对 Microsoft Visual C++ 而言,在其它的编译器中可能其它不同的宏。
  • 这里是代码:

     

    [cpp] view plaincopy
    1. #include "stdafx.h"  
    2. #include <stdio.h>  
    3. #include <stdarg.h>  
    4. #include <windows.h>  
    5.   
    6. void _trace(char *fmt, ...);  
    7.   
    8. #ifdef _DEBUG  
    9. #define ASSERT(x) {if(!(x)) _asm{int 0x03}}  
    10. #define VERIFY(x) {if(!(x)) _asm{int 0x03}}     // 译注:为调试版本时产生中断有效  
    11. #else  
    12. #define ASSERT(x)  
    13. #define VERIFY(x) x                             // 译注:为发行版本时不产生中断  
    14. #endif  
    15.   
    16. #ifdef _DEBUG  
    17. #define TRACE _trace      
    18. #else  
    19. inline void _trace(LPCTSTR fmt, ...) { }  
    20. #define TRACE    
    21. #endif  
    22.   
    23.   
    24. void _trace(char *fmt, ...)  
    25. {  
    26.     char out[1024];  
    27.     va_list body;  
    28.     va_start(body, fmt);  
    29.     vsprintf(out, fmt, body);     // 译注:格式化输入的字符串 fmtt  
    30.     va_end(body);                 //       到输出字符串 ou  
    31.     OutputDebugStringA(out);       // 译注:输出格式化后的字符串到调试器  
    32. }  

    RFID管理系统集成商 RFID中间件 条码系统中间层 物联网软件集成