Visual C++ MFC 中常用宏的含義
發(fā)表時間:2024-01-01 來源:明輝站整理相關(guān)軟件相關(guān)文章人氣:
[摘要]AND_CATCHAND_CATCH AND_CATCH(exception_class,exception _object_point_name) 說明:定義一個代碼塊,它用于獲取廢除當(dāng)前TRY塊中的附加異常類型。使用CATCH宏以獲得一個異常類型,然后使用AND_CATCH宏獲得隨后的異常處理...
AND_CATCHAND_CATCH
AND_CATCH(exception_class,exception _object_point_name)
說明:
定義一個代碼塊,它用于獲取廢除當(dāng)前TRY塊中的附加異常類型。使用CATCH宏以獲得一個異常類型,然后使用AND_CATCH宏獲得隨后的異常處理代碼可以訪問異常對象(若合適的話)已得到關(guān)于異常的特別原因的更多消息。在AND_CATCH塊中調(diào)用THROW_LAST宏以便把處理過程移到下個外部異?蚣堋ND_CATCH可標(biāo)記CATCH或AND_CATCH塊的末尾。
注釋:
AND_CATCH塊被定義成為一個C++作用域(由花括號來描述)。若用戶在此作用域定義變量,那么記住他們只在此作用域中可以訪問。他也用于exception_object_pointer_name變量。
ASSERT
ASSERT(booleanExpression)
說明:
計算變量的值。如果結(jié)構(gòu)的值為0,那么此宏便打印一個診斷消息并且成訊運行失敗。如果條件為非0,那么什么也不做。 診斷消息的形式為: assertion failed in file in line 其中name是元文件名,num是源文件中運行失敗的中斷號。 在Release版中,ASSERT不計算表達(dá)式的值也就不中斷程序。如果必須計算此表達(dá)式的值且不管環(huán)境如何那么用VERIFY代替ASSERT。
注釋:
ASSERT只能在Debug版中用
ASSERT_VAILD
ASSERT_VAILD(pObject)
說明:
用于檢測關(guān)于對象的內(nèi)部狀態(tài)的有效性。ASSERT_VALID調(diào)用此對象的AssertValid成員函數(shù)(把它們作為自己的變量來傳遞)。在Release版中ASSERT_VALID什么也不做。在DEBUG版中,他檢查指針,以不同于NULL的方式進行檢查,并調(diào)用對象自己的AssertValid成員函數(shù)。如果這些檢測中有任何一個失敗的話,那么他會以與ASSERT相同的方法顯示一個警告的消息。
注釋:
此函數(shù)只在DEBUG版中有效。
BEGIN_MESSAGE_MAP
BEGIN_MESSAGE_MAP(the class,baseclass)
說明:
使用BEGIN_MESSAGE_MAP開始用戶消息映射的定義。在定義用戶類函數(shù)的工具(.cpp)文件中,以BEGIN_MESSAGE_MAP宏開始消息映射,然后為每個消息處理函數(shù)增加宏項,接著以END_MESSAGE_MAP宏完成消息映射。
CATCH
CATCH(exception_class,exception_object_pointer_name)
說明:
使用此用定義一個代碼塊,此代碼用來獲取當(dāng)前TRY塊中都一個異常類型。異常處理代碼可以訪問異常對象,如何合適的話,就會得到關(guān)于異常的特殊原因的更多消息。調(diào)用THROW_LAST宏以把處理過程一下一個外部異?蚣,如果exception-class是類CExceptioon,那么會獲取所有異常類型。用戶可以使用CObject::IsKindOf成員函數(shù)以確定那個特別異常被排除。一種獲取異常的最好方式是使用順序的AND_CATCH語句,每個帶一個不同的異常類型。此異常類型的指針由宏定義,用戶不必定義。
注釋:
此CATCH塊被定義作一個C++范圍(由花括號描述)。如用戶在此范圍定義變量,那么它們只在吃范圍內(nèi)可以訪問。他還可以用于異常對象的指針名。
DEBUG_NEW
#define new DEBUG_NEW
說明:
幫助查找內(nèi)存錯誤。用戶在程序中使用DEBUG_NEW,用戶通常使用new運算符來從堆上分配。在Debug模式下(但定義了一個DEBUG符號),DEBUG_NEW為它分配的每個對象記錄文件名和行號。然后,在用戶使用CMemoryState::DumpAllObjectSince成員函數(shù)時,每個以DEBUG_NEW分配的對象分配的地方顯示出文件名和行號。 為了使用DEBUG_NEW,應(yīng)在用戶的資源文件中插入以下指令: #define new DEBUG_NEW 一旦用戶插入本指令,預(yù)處理程序?qū)⒃谑褂胣ew的地方插入DEBUG_NEW,而MFC作其余的工作。但用戶編譯自己的程序的一個發(fā)行版時,DEBUG_NEW便進行簡單的new操作,而且不產(chǎn)生文件名和行號消息。
DECLARE_DYNAMIC
DECLARE_DYNAMIC(class_name)
說明:
但從CObject派生一個類時,此宏增加關(guān)于一個對象類的訪問運行時間功能。把DECLARE_DYNAMIC宏加入類的頭文件中,然后在全部需要訪問詞類對象的.CPP文件中都包含此模塊。如果像所描述那樣使用DELCARE_DYNAMIC和IMPLEMENT_DYNAMIC宏,那么用戶便可使用RUNTIME_CLASS宏和CObject::IsKindOf函數(shù)以在運行時間決定對象類。如果DECLARE_DYNAMIC包含在類定義中,那么IMPLEMETN_DYNAMIC必須包含在類工具中。
DECLARE_DYNCREATE
DECLARE_DYNCREATE(class_name)
說明:
使用DECLARE_DYNCRETE宏以便允許CObject派生類的對象在運行時刻自動建立。主機使用此功能自動建立新對象,例如,但它在串行化過程中從磁盤讀一個對象時,文件及視圖和框架窗應(yīng)該支持動態(tài)建立,因為框架需要自動建立它。把DECLARE_DYNCREATE宏加入類的.H文件中,然后在全部需要訪問此類對象的.CPP文件中包含這一模式。如果DECLARE_DYNCREATE包含在類定義中,那么IMPLEMENT_DYNCREATE必須包含在類工具中。
DECLARE_MESSAGE_MAP
DECLARE_MESSAGE_MAP()
說明:
用戶程序中的每個CCmdTarget派生類必須提供消息映射以處理消息。在類定義的末尾使用DECLARE_MESSAGE_MAP宏。接著,在定義類成員函數(shù)的.CPP文件中,使用BEGIN_MESSAGE_MAP宏,每個用戶消息處理函數(shù)的宏項下面的列表以及END_MESSAGE_MAP宏。
注釋:
如果在DECLARE_MESSAGE_MAP之后定義任何一個成員,那么必須為他們指定一個新存取類型(公共的,私有的,保護的)。
DECLARE_SERIAL
DECLARE_SERIAL(class_name)
說明:
DECLARE_SERIAL為一個可以串行化的CObject派生類產(chǎn)生必要的C++標(biāo)題代碼。串行化是把某個對象的內(nèi)容從一個文件讀出和寫入一文件。在.H文件中使用DECLARE_SERIAL宏,接著在需要訪問此類對象的全部.CPP文件中包含此文件。如果DECLARE_SERIAL包含在類定義中,那么IMPLEMENT_SERIAL必須包含在類工具中。DECLARE_SERIAL宏包含全部DECLARE_DYNAMIC,IMPLEMENT_DYCREATE的功能。
END_CATCH
END_CATCH
說明:
標(biāo)識最后的CATCH或AND_CATCH塊的末尾。
END_MESSAGE_MAP
END_MESSAGE_MAP
說明:
使用END_MESSAGE_MAP宏結(jié)束用戶的消息映射定義
IMPLEMENT_DYNAMIC
IMPLEMENT_DYNAMIC(class_name,base_class_name)
說明:
通過運行時在串行結(jié)構(gòu)中為動態(tài)CObject派生類訪問類名和位置來產(chǎn)生必要的C++代碼。在.CPP文件中使用IMPLEMENT_DYNAMIC宏,接著一次鏈接結(jié)果對象代碼
IMPLEMENT_DYNCREATE
IMPLEMENT_DYNCREATE(class_name,base_class_name)
說明:
通過DECLARE_DYNCREATE宏來使用IMPLEMENT_DYNCREATE宏,以允許CObject派生類對象在運行時自動建立。主機使用此功能自動建立對象,例如,但它在串行化過程中從磁盤讀去一個對象時,他在類工具里加入IMPLEMENT_DYNCREATE宏。若用戶使用DECLARE_DYNCREATE和IMPLEMENT_DYNCREATE宏,那么接著使用RUNTIME_CLASS宏和CObject::IsKindOf成員函數(shù)以在運行時確定對象類。若declare_dyncreate包含在定義中,那么IMPLEMENT_DYNCREATE必須包含在類工具中。
IMPLEMENT_SERIAL
IMPLEMENT_SERIAL(class_name,base_class_name,wSchema)
說明:
通過運行時在串行結(jié)構(gòu)中動態(tài)CObject派生類訪問類名和位置來建立必要的C++代碼。在.CPP文件中使用IMPLEMENT_SERIAL宏,然后一次鏈接結(jié)果對象代碼。
ON_COMMAND
ON_COMMAND(id,memberFxn)
說明:
此宏通過ClassWizard或手工插入一個消息映射。它表明那個函數(shù)將從一個命令用戶接口(例如一個菜單項或toolbar按鈕)處理一個命令消息。當(dāng)一個命令對象通過指定的ID接受到一個Windows WM_COMMAND消息時,ON_COMMAND將調(diào)用成員函數(shù)memberFxn處理此消息。在用戶的消息映射中,對于每個菜單或加速器命令(必須被映射到一個消息處理函數(shù))應(yīng)該確實有一個ON_COMMAND宏語句。
ON_CONTROL
ON_CONTROL(wNotifyCode,id,memberFxn)
說明:
表明哪個函數(shù)將處理一個常規(guī)控制表示消息?刂茦(biāo)識消息是那些從一個控制夫發(fā)送到母窗口的消息。
ON_MESSAGE
ON_MESSAGE(message,memberFxn)
說明:
指明哪個函數(shù)將處理一用戶定義消息。用戶定義消息通常定義在WM_USER到0x7FF范圍內(nèi)。用戶定義消息是那些不是標(biāo)準(zhǔn)Windows WM_MESSAGE消息的任何消息。在用戶的消息映射中,每個必須被映射到一個消息處理函數(shù)。用戶定義消息應(yīng)該有一個ON_MESSAGE宏語句。
ON_REGISTERED_MESSAGE
ON_REGISTERED_MESSAGE(nmessageVarible,memberFxn)
說明:
Windows的RegisterWindowsMesage函數(shù)用于定義一個新窗口消息,此消息保證在整個系統(tǒng)中是唯一的。此宏表明哪個函數(shù)處理已注冊消息。變量nMessageViable應(yīng)以NEAR修飾符來定義。
ON_UPDATE_COMMAND_UI
ON_UPDATE_COMMAND_UI(id,memberFxn)
說明:
此宏通常通過ClassWizard被插入一個消息映射,以指明哪個函數(shù)將處理一個用戶接口個更改命令消息。在用戶的消息映射中,每個用戶接口更改命令(比訊被映射到一個消息處理函數(shù))應(yīng)該有一個ON_UPDATE_COMMAND_UI宏語句。
ON_VBXEVENT
ON_VBXEVENT(wNotifyCode,memberFxn)
說明:
此宏通常通過ClassWizard被插入一個消息映射,以指明哪個函數(shù)將處理一個來自VBX控制的消息。在用戶的消息映射中每個被映射到一消息處理函數(shù)的VBX控制消息應(yīng)該有一個宏語句。
RUNTIME_CLASS
RUNTIME_CLASS(class_name)
說明:
使用此宏從c++類民眾獲取運行時類結(jié)構(gòu)。RUNTIME_CLASS為由class_name指定的類返回一個指針到CRuntimeClass結(jié)構(gòu)。只有以DECLARE_DYNAMIC,DECLARE_DYNCREATE或DECLARE_SERIAL定義的CObject派生類才返回到一個CRuntimeClass結(jié)構(gòu)的指針。
THROW
THROW(exception_object_pointer)
說明:
派出指定的異常。THROW中斷程序的運行,把控制傳遞給用戶程序中的相關(guān)的CATCH塊。如果用戶沒有提供CATCH塊,那么控制被傳遞到一個MFC模塊,他打印出一個錯誤并終止運行。
THROW_LAST
THROW_LAST()
說明:
此宏允許用戶派出一個局部建立的異常。如果用戶試圖排除一個剛發(fā)現(xiàn)的異常,那么一般此異常將溢出并被刪除。使用THROW_LAST,此異常被直接傳送到下一個CATCH處理程序。
TRACE
TRACE(exp)
說明:
把一個格式化字符串送到轉(zhuǎn)儲設(shè)備,例如,文件或調(diào)試監(jiān)視器,而提供與printf相似的功能。同MS_DOS下C程序的printf一樣,TRACE宏是一個在程序運行時跟蹤變量值的方便形式。在DEBUG環(huán)境中,TRACE宏輸出到afxDump。在Release版中他不做任何工作。
注釋:
此宏只在MFC的DEBUG版中有效。
TRACE0
TRACE0(exp)
說明:
與TRACE相似,但他把跟蹤字符串放在代碼段中,而不是DGROUP,因此使用少的DGROUP空間。TRACE0是一組跟蹤宏的一個變體,這些宏可用于調(diào)試輸出。這一組包括TRACE0,TRACE1,TRACE2和TRACE3,這些宏不同在于所取參數(shù)的數(shù)目不同。TRACE0只取一個格式化字符串并可用于簡單文本消息。TRACE1取一格式化字符串加上一個變量——一個將轉(zhuǎn)儲的變量。同樣,TRACE2,TRACE3分別取2個或3個參數(shù)(在格式化字符串之后)。如果用戶以便以了應(yīng)用程序的發(fā)行版,那么它只把數(shù)據(jù)轉(zhuǎn)儲到afxDump。
注釋:
此宏只在MFC的DEBUG中有效。
TRACE1
TRACE1(exp,param1)
說明:
參見TRACE0
TRACE2
TRACE2(exp,param1,param2)
說明:
參見TRACE0
TRACE3
TRACE3(exp,param1,param2,param3)
說明:
TRY
TRY
說明:
使用此宏建立一TRY塊。一個TRY識別一個可排除異常的代碼塊。這些異常在隨后的CATCH和AND_CATCH塊處理。傳遞是允許的:異?梢詡鬟f一個外部TRY塊,或者忽略它們或者使用THROW_LAST宏。
VERIFY
VERIFY(booleanExpression)
說明:
在MFC的DEBUG版中,VERIFY宏計算它的變量值。 如果結(jié)果為0,那么宏打印一個診斷消息并中止程序。如果條件不為0,那么什么工作也不作。 診斷有如下形式: assertion failed in file in line 其中name是源文件的名字,num是在源文件中失敗的中止行號。在MFC的Release版中,VERIFY計算表達(dá)式值但不打印或中止程序。例如:如果表達(dá)式是個函數(shù)調(diào)用,那么調(diào)用成功。