C++中TRACE宏及assert()函數的使用

C++中TRACE宏及assert()函數的使用       
 
C++中TRACE宏的使用
TRACE宏對於VC下程序調試來說是很有用的東西,有着類似printf的功能;該宏僅僅在程序的DEBUG版本中出現,當RELEASE的時候該宏就完全消失了,從而幫助你調試也在RELEASE的時候減少代碼量。
使用非常簡單,格式如下:
TRACE("DDDDDDDDDDD");
TRACE("wewe%d",333);
同樣還存在TRACE0,TRACE1,TRACE2。。。分別對應0,1,2。。個參數
TRACE信息輸出到VC IDE環境的輸出窗口(該窗口是你編譯項目出錯提示的那個窗口),但僅限於你在VC中運行你的DEBUG版本的程序。
TRACE信息還可以使用DEBUGVIEW來捕獲到。這種情況下,你不能在VC的IDE環境中運行你的程序,而將BUILD好的DEBUG版本的程序單獨運行,這個時候可以在DEBUGVIEW的窗口看到DEBUGVIE格式的輸出了。
VC中TRACE的用法有以下四種:
1:
TRACE  ,就是不帶動態參數輸出字符串,   類似C的printf("輸出字符串"); 
    
2:
  TRACE   中的字符串可以帶一個參數輸出  , 類似C的printf("...%d",變量);     
    
3:
  TRACE   可以帶兩個參數輸出,類似C的printf("...%d...%f",變量1,變量2);     
    
4:
  TRACE   可以帶三個參數輸出,類似C的printf("...%d,%d,%d",變量1,變量2,變量3);
TRACE 宏有點象我們以前在C語言中用的Printf函數,使程序在運行過程中輸出一些調試信息,使我們能瞭解程序的一些狀態。但有一點不同的是:

TRACE 宏只有在調試狀態下才有所輸出,而以前用的Printf 函數在任何情況下都有輸出。和Printf 函數一樣,TRACE函數可以接受多個參數如:
int x = 1;
int y = 16;
float z = 32.0;
TRACE( "This is a TRACE statement\n" );
TRACE( "The value of x is %d\n", x );
TRACE( "x = %d and y = %d\n", x, y );
TRACE( "x = %d and y = %x and z = %f\n", x, y, z );
要注意的是TRACE宏只對Debug 版本的工程產生作用,在Release 版本的工程中,TRACE宏將被忽略。

TRACE 宏的利用。。。

TRACE 宏有點象我們以前在C語言中用的Printf函數,使程序在運行過程中輸出一些調試信息,使我們能瞭解程序的一些狀態。但有一點不同的是:
TRACE 宏只有在調試狀態下才有所輸出,而以前用的Printf 函數在任何情況下都有輸出。和Printf 函數一樣,TRACE函數可以接受多個參數如:

int x = 1;
int y = 16;
float z = 32.0;
TRACE( "This is a TRACE statement\n" );
TRACE( "The value of x is %d\n", x );
TRACE( "x = %d and y = %d\n", x, y );
TRACE( "x = %d and y = %x and z = %f\n", x, y, z );

要注意的是TRACE宏只對Debug 版本的工程產生作用,在Release 版本的工程中,TRACE宏將被忽略。

----------------------------------------------------------------------------------assert()函數的應用-----------------------------------------------------------------------------------------------------------

C++ assert()函數的應用方式將會在這篇文章中進行詳解,相信對此有興趣的朋友們應該可以根據我們介紹的內容充分掌握這方面的應用技巧。 
作爲一個經驗豐富的編程人員來說,對於C++編程語言應該不會陌生的,它的應用可以幫助我們輕鬆的實現各種功能需求。在這裏我們會對C++ assert()函數的一些基本應用做一個詳細介紹。

assert宏的原型定義在< assert.h>中,其作用是如果它的條件返回錯誤,則終止程序執行,原型定義:

#include < assert.h>   void assert( int expression ); C++ assert()函數的作用是現計算表達式 expression ,如果其值爲假(即爲0),那麼它先向stderr打印一條出錯信息,然後通過調用 abort 來終止程序運行。請看下面的程序清單badptr.c:

#include < stdio.h>   #include < assert.h>   #include < stdlib.h>   int main( void )   {   FILE *fp;   fp = fopen( "test.txt", "w" );//以可寫的方式打開一個文件,如果不存在就創建一個同名文件   assert( fp ); //所以這裏不會出錯   fclose( fp );   fp = fopen( "noexitfile.txt", "r" );//以只讀的方式打開一個文件,如果不存在就打開文件失敗   assert( fp ); //所以這裏出錯   fclose( fp ); //程序永遠都執行不到這裏來   return 0;   }   [root@localhost error_process]# gcc badptr.c   [root@localhost error_process]# ./a.out   a.out: badptr.c:14: main: Assertion `fp' failed. 已放棄

使用C++ assert()函數的缺點是,頻繁的調用會極大的影響程序的性能,增加額外的開銷。 在調試結束後,可以通過在包含#include < assert.h>的語句之前插入 #define NDEBUG 來禁用assert調用,示例代碼如下:

#include < stdio.h>   #define NDEBUG   #include < assert.h>

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章