中用于調試程序的幾個宏的使用技巧的
一、TRACE宏
當選擇了Debug目標,并且afxTraceEnabled變量被置為TRUE時,TRACE宏也就隨之被激活了。但在程序的Release版本中,它們是被完全禁止的。下面是一個典型的TRACE語句:
…
int nCount =9;
CString strDesc(\"total\");
TRACE(\"Count =%d,Description =%s\\n\",nCount,strDesc);
…
可以看到,TRACE語句的工作方式有點像C語言中的printf語句,TRACE宏參數的個數是可變的,因此使用起來非常容易。如果查看MFC的源代碼,你根本找不到TRACE宏,而只能看到TRACE0、TRACE1、TRACE2和TRACE3宏,它們的參數分別為0、1、2、3。
寧夏吉元冶金集團有限公司 二、ASSERT宏
如果你設計了一個函數,該函數需要一個指向文檔對象的指針做參數,但是你卻錯誤地用一個視圖指針調用了這個函數。這個假的地址將導致視數據的破壞。現在,這種類型的問題可以被完全避免,只要在該函數的開始處實現一個ASSERT測試,用來檢測該指針是否真正指向一個文檔對象。一般來講,編程者在每個函數的開始處均應例行公事地使用assertion。ASSERT宏將會判斷表達式,如果一個表達式為真,執行將繼續,否則,程序將顯示一條消息并且暫停,你可以選擇忽視這條錯誤并繼續、終止這個程序或者是跳到Debug器中。下面一例演示了如何使用一個ASSERT宏去驗證一個語句。
void foo( char p, int size )
{
ASSERT( p != 0 ); //確認緩沖區的指針是有效的
ASSERT( ( size = 100 ); //確認緩沖區至少有100個字節
// Do the foo calculation
}
這些語句不產生任何代碼,除非—DEBUG處理器標志被設置。Visual C++只在Debug版本設置這些標志,而在Release版本不定義這些標志。當—DEBUG被定義時,兩個assertions將產生如下代碼:
//ASSERT( p != 0 );
do{
if( !(p != 0) AfxAssertFailedLine(—FILE—,—LINE—) )
AfxDebugBreak();
}while(0);
//ASSERT((size 〉= 100);
do{
if(!(size 〉= 100) &&AfxAssertFailedLine(—FILE—,—LINE—))
AfxDebugBreak();
}while(0);
Do-while循環將整個assertion封裝在一個單獨的程序塊中,使得編譯器編譯起來很舒暢。If語句將求取表達式的值并且當結果為零時調用AfxAssertFailedLine()函數。這個函數將彈出一個對話框,其中提供三個選項“取消、重試或忽略”,當你選取“重試”時,它將返回TRUE。重試將導致對AfxDebugBreak()函數的調用,從而激活調試器。
Do-while循環將整個assertion封裝在一個單獨的程序塊中,使得編譯器編譯起來很舒暢。If語句將求取表達式的值并且當結果為零時調用AfxAssertFailedLine()函數。這個函數將彈出一個對話框,其中提供三個選項“取消、重試或忽略”,當你選取“重試”時,它將返回TRUE。重試將導致對AfxDebugBreak()函數的調用,從而激活調試器。
AfxAssertFailedLine()是一個未正式公布的函數,它的功能就是顯示一個消息框。該函數的源代碼駐留在p中。函數中的—FILE—和—LINE—語句是處理器標志,它們分別指定了源文件名和當前的行號。
AfxAssertFailedLine()是一個未正式公布的函數,它的功能就是顯示一個消息框。該函數的源代碼駐留在p中。函數中的—FILE—和—LINE—語句是處理器標志,它們分別指定了源文件名和當前的行號。
三、VERIFY 宏
因為assertion只能在程序的Debug版本中起作用,在表達式中不可以包含賦值語句、增加語句(++)或者是減少語句(--),因為,這些語句實際改變數據。可有時你可能想要驗證一個能動的表達式,使用一個賦值語句。那么就到了用VERIFY宏來替代ASSERT。例如:
void foo(char p, int size )
{
char q;
VERIFY(q = p);
ASSERT((size 〉= 100);
// Do the foo calculation
// Do the foo calculation
}
在Debug模式下,ASSERT和VERIFY是一回事,但是在Release模式下,VERIFY宏仍然測試表達式而assertion卻不起任何作用。可以說,在Release模式下,ASSERT語句被刪除了。
請注意,如果你在一個ASSERT語句中錯誤地使用了一個能動的表達式,編譯器將不做任何警告地忽略它。在Release模式下,該表達式就會被無聲息地刪除掉,這將會導致程序的錯誤運行。由于Release版的程序通常不包含Debug信息,這類錯誤將很難被發現。
查看本文來源
長沙婦科哪家醫院好石家莊專業治療牛皮癬醫院
昆明包皮包莖治療多少錢
- 3年狂掙得82億!華強北“小混混”,竟靠著一根數據線拿捏了蘋果
- 等你老了,到底跟兒子住好還是跟女兒住好?聽聽土生土長人是咋說的
- 家電耐腐蝕翅片管散熱器
- "零售之王"換帥出爐!27年"老招行"王良接棒,保持戰略執行不偏移、不動搖
- 還記得《十八歲的天空》里的校花藍菲琳嗎?她現在高約這樣啦!
- 江南大學陳雪團隊報道——Muse細胞降低神經炎癥反應的有助于
- 稱重傳感器616-50KG 特貝特 tedea
- 自制醬牛肉,大廚:3種料最重要!保證顏色紅亮,軟爛入味,香
- 終于不用被踹了 戈蘭德把頭像換成與楊鳴的擁抱照
- 是否存在收入、成本跨期確認或虛增收入、成本情形?鼎龍傳統文化收年報問詢函
- 買上海的老洋房,只有40㎡,翻新后,連我都認不出了!
- 寶寶和姥爺姥姥要分開,雙方不舍的過場令人鼻酸,網友:隔代親啊