情況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個宏之一。
DEBUG_NEW定位內存泄露並且跟蹤文件名.
////////////////////////////////////////////////////////////////////////
情況3:
#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
ANSI C 的6個宏:
6個分別是
__DATE__
__FILE__
__LINE__
__STDC__
__TIME__
__TIMESTAMP__