• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            兔子的技術博客

            兔子

               :: 首頁 :: 聯系 :: 聚合  :: 管理
              202 Posts :: 0 Stories :: 43 Comments :: 0 Trackbacks

            留言簿(10)

            最新評論

            閱讀排行榜

            評論排行榜

            使用 AFX_EXT_CLASS 導出和導入 
            擴展 DLL 使用 AFX_EXT_CLASS 宏導出類;鏈接到擴展 DLL 的可執行文件使用該宏導入類。用于生成擴展 DLL 的相同頭文件可通過 AFX_EXT_CLASS 宏與鏈接到 DLL 的可執行文件一起使用。
            在 DLL 的頭文件中,將 AFX_EXT_CLASS 關鍵字添加到類的聲明中,如下所示:
            class AFX_EXT_CLASS CMyClass : public CDocument
            {
            // <body of class>
            };
            當定義了預處理器符號 _AFXDLL 和 _AFXEXT 時,該宏被 MFC 定義為 __declspec(dllexport)。但當定義了 _AFXDLL 而未定義 _AFXEXT 時,該宏被定義為 __declspec(dllimport)。定義后,預處理器符號 _AFXDLL 指示共享 MFC 版本正在由目標可執行文件(DLL 或應用程序)使用。當 _AFXDLL 和 _AFXEXT 都定義了時,這指示目標可執行文件是擴展 DLL。
            由于從擴展 DLL 導出時,AFX_EXT_CLASS 被定義為 __declspec(dllexport),因此可以導出整個類,而不必將該類的所有符號的修飾名放到 .def 文件中。此方法由 MFC 示例 DLLHUSK 使用。
            雖然使用此方法可以避免創建 .def 文件和類的所有修飾名,但由于名稱可以按序號導出,因此創建 .def 文件的效率更高。若要使用 .def 文件導出方法,請將下列代碼放在頭文件的開頭和結尾處:
            #undef AFX_DATA
            #define AFX_DATA AFX_EXT_DATA
            // <body of your header file>
            #undef AFX_DATA
            #define AFX_DATA
            警告
            導出內聯函數時要小心,因為它們有可能導致版本沖突。內聯函數擴展到應用程序代碼中;因此,如果以后重寫內聯函數,除非重新編譯應用程序本身,否則內聯函數不會被更新。通常,不用重新生成使用 DLL 函數的應用程序就可以更新 DLL 函數。
             
            導出類中的個別成員
            有時,您可能希望導出類中的個別成員。例如,如果導出 CDialog 派生類,可能只需要導出構造函數和 DoModal 調用。可以對需要導出的個別成員使用 AFX_EXT_CLASS。
            例如:
            class CExampleDialog : public CDialog
            {
            public:
               AFX_EXT_CLASS CExampleDialog();
               AFX_EXT_CLASS int DoModal();
               ...
               // rest of class definition
               ...
            };
            您不再導出類的所有成員,但由于 MFC 宏的工作方式,您可能會遇到其他問題。幾個 MFC 的 Helper 宏實際聲明或定義數據成員。因此,還必須從 DLL 導出這些數據成員。
            例如,當生成擴展 DLL 時,DECLARE_DYNAMIC 宏的定義如下:
            #define DECLARE_DYNAMIC(class_name) \
            protected: \
               static CRuntimeClass* PASCAL _GetBaseClass(); \
            public: \
               static AFX_DATA CRuntimeClass class##class_name; \
               virtual CRuntimeClass* GetRuntimeClass() const; \
            以 static AFX_DATA 打頭的行聲明類的內部靜態對象。若要正確導出該類并從客戶端可執行文件訪問運行時信息,必須導出此靜態對象。由于靜態對象是用 AFX_DATA 修飾符聲明的,因此只需在生成 DLL 時將 AFX_DATA 定義為 __declspec(dllexport),并在生成客戶端可執行文件時將 AFX_DATA 定義為 __declspec(dllimport)。由于已經以此方式定義了 AFX_EXT_CLASS,因此只需參考類定義,將 AFX_DATA 重定義為與 AFX_EXT_CLASS 相同。
            例如:
            #undef  AFX_DATA
            #define AFX_DATA AFX_EXT_CLASS
            class CExampleView : public CView
            {
               DECLARE_DYNAMIC()
               // ... class definition ...
            };
            #undef  AFX_DATA
            #define AFX_DATA
            MFC 總是在其宏的內部定義的數據項上使用 AFX_DATA 符號,因此此技術適用于所有這類情況。例如,它適用于 DECLARE_MESSAGE_MAP。


            posted on 2010-06-17 13:29 會飛的兔子 閱讀(1639) 評論(0)  編輯 收藏 引用 所屬分類: C++庫,組件C++及開發環境
            日本道色综合久久影院| 久久综合久久自在自线精品自 | 观看 国产综合久久久久鬼色 欧美 亚洲 一区二区 | 国产精品18久久久久久vr| 91精品国产91久久久久福利| 久久99精品久久久久久齐齐 | 久久午夜羞羞影院免费观看| 欧美噜噜久久久XXX| 国产精品综合久久第一页| 欧美日韩中文字幕久久久不卡| 亚洲性久久久影院| 国产人久久人人人人爽| 久久夜色精品国产www| 久久99精品久久久久久久不卡 | 亚洲国产欧美国产综合久久| 久久99精品国产| 囯产极品美女高潮无套久久久| 久久777国产线看观看精品| 国产精品99久久精品爆乳| 久久久www免费人成精品| 国产三级观看久久| 久久99国产精品久久久| 久久亚洲春色中文字幕久久久| 99久久国产主播综合精品| 97精品依人久久久大香线蕉97| 91久久香蕉国产熟女线看| 99久久精品免费看国产一区二区三区| 久久久久人妻精品一区二区三区 | 亚洲v国产v天堂a无码久久| 国产午夜福利精品久久2021| 国产成人精品综合久久久久 | 久久e热在这里只有国产中文精品99 | 色综合久久88色综合天天| 伊人久久亚洲综合影院| 狠狠人妻久久久久久综合| 色综合久久天天综合| 色综合久久综合网观看| 99精品伊人久久久大香线蕉| 色偷偷888欧美精品久久久| 91久久香蕉国产熟女线看| 麻豆国内精品久久久久久|