#ifdef _DEBUG

本文介绍了VC++中通过条件编译宏_DEBUG实现的调试技巧,包括内存泄漏检测和错误定位等功能。详细解析了如何利用DEBUG_NEW宏及AssertValid、Dump等函数进行有效的调试。

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

#ifdef _DEBUG
          #define new DEBUG_NEW
          #undef THIS_FILE
          static char THIS_FILE[] = __FILE__;
#endif

 

转载自:http://blog.youkuaiyun.com/shijizhisheng/archive/2007/11/29/1908054.aspx

 

1
#ifdef _DEBUG
         virtual void AssertValid() const;                                     //assert(断言)valid(有效的,正确的)
         virtual void Dump(CDumpContext& dc) const;               //存储上下文
#endif


这两个函数是调试用的,第一个函数检查可用性,即是否有效。第二个函数如果未更改的话,最终调用的是Cwnd::Dump(); 输出窗口类名,标题名等一系列信息(在输出窗口中)


#ifdef _DEBUG


#endif


这是条件编译,即如果有#define _DEBUG这两个函数会编译,否则忽略,
当你用debug生成时(相对于release)开发环境则自动的加上这个宏定义,这两个函数有效。

 

2


#ifdef   _DEBUG                                                                     //   判断是否定义_DEBUG   
         #undef   THIS_FILE                                                      //   取消THIS_FILE的定义   
         static   char   THIS_FILE[]=__FILE__;                          //   定义THIS_FILE指向文件名   
         #define  new    DEBUG_NEW                                      //   定义调试new宏,取代new关键字  
#endif                                                                                 //   结束      
如果定义了_DEBUG,表示在调试状态下编译,因此相应修改了两个符号的定义
THIS_FILE是一个char数组全局变量,字符串值为当前文件的全路径,这样在Debug版本中当程序出错时出错处理代码可用这个变量告诉你是哪个文件中的代码有问题。
定义 _DEBUG后,由于定义了_DEBUG,编译器确定这是一个调试,编译#ifdef   _DEBUG和#endif之间的代码。#undef   表示清除当前定义的宏,使得THIS_FILE无定义。__FILE__   是编译器能识别的事先定义的ANSI   C   的6个宏之一。#define   new   DEBUG_NEW  
DEBUG_NEW定位内存泄露并且跟踪文件名.
////////////////////////////////////////////////////////////////////////
///另一种解释
#ifdef     _DEBUG                                                                           //如果是debug状态   
         #undef     THIS_FILE                                                            //清除THIS_FILE   
         static     char     THIS_FILE[]=__FILE__;                              //定义THIS_FILE为                   

                                                                                                     //__FILE__(这是当前文件全路径名字)       
         #define    new     DEBUG_NEW                                           //定义new为DEBUG_NEW(这个可以检测到内存泄露

                                                                                                    //之类的问题,其实就是可以使用crt开头的那几个调试函数)  
#endif

 

 

 

转载自:http://blog.youkuaiyun.com/Sco_field/archive/2008/12/17/3537543.aspx


 在用vc时,利用AppWizard会产生如下代码:

#ifdef _DEBUG
          #define new DEBUG_NEW
          #undef THIS_FILE
          static char THIS_FILE[] = __FILE__;
#endif

对于

#define new DEBUG_NEW
首先看msdn的解释:

Assists in finding memory leaks. You can use DEBUG_NEW everywhere in your program that you would ordinarily use the new operator to allocate heap storage.

In debug mode (when the _DEBUG symbol is defined), DEBUG_NEW keeps track of the filename and line number for each object that it allocates. Then, when you use the CMemoryState::DumpAllObjectsSince member function, each object allocated with DEBUG_NEW is shown with the filename and line number where it was allocated.

To use DEBUG_NEW, insert the following directive into your source files:

#define new DEBUG_NEW

Once you insert this directive, the preprocessor will insert DEBUG_NEW wherever you use new, and MFC does the rest. When you compile a release version of your program, DEBUG_NEW resolves to a simple new operation, and the filename and line number information is not generated.

 


再查看定义:

#ifdef _DEBUG

          void* AFX_CDECL operator new(size_t nSize, LPCSTR lpszFileName, int nLine);
          #define DEBUG_NEW new(THIS_FILE, __LINE__)

#else

          #define DEBUG_NEW new

#endif

这样就很清楚了,当在debug模式下时,我们分配内存时的new被替换成DEBUG_NEW,而这个DEBUG_NEW不仅要传入内存块的大小,还要传入源文件名和行号,这就有个好处,即当发生内存泄漏时,我们可以在调试模式下定位到该问题代码处。若删掉该句,就不能进行定位了。而在release版本下的new就是简单的new,并不会传入文件名和行号。

因此,我们在开发代码阶段,保留上述代码是值得的

 

 

 

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值