• <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>
            隨筆 - 119  文章 - 290  trackbacks - 0

            博客搬家了哦,請(qǐng)移步
            叫我abc

            常用鏈接

            留言簿(12)

            隨筆分類

            我的博客

            搜索

            •  

            積分與排名

            • 積分 - 303764
            • 排名 - 84

            最新評(píng)論

            閱讀排行榜

            最近知道可以使用MFC常規(guī)DLL導(dǎo)出一些功能,交給其他程序使用,即使那個(gè)程序不是MFC程序。

            嘗試的環(huán)境大概是這樣的,MFC常規(guī)DLL,以及普通的控制臺(tái)程序。
            MFC常規(guī)DLL的一個(gè)導(dǎo)出函數(shù)
            1__declspec( dllexport ) void create_frm2()
            2{
            3    CFileDialog dlg( TRUE );
            4    dlg.DoModal();
            5}

            調(diào)用導(dǎo)出函數(shù)的應(yīng)用程序
            1int _tmain(int argc, _TCHAR* argv[])
            2{
            3    create_frm2();
            4
            5    return 0;
            6}

            不過在嘗試的過程中,出了點(diǎn)問題,在調(diào)用導(dǎo)出函數(shù)的時(shí)候不是崩潰就是大量的DEBUG ASSERT,看起來卡在CFileDialog的構(gòu)造函數(shù)上了。
            請(qǐng)教同事,才知道大概緣由。
            在MFC常規(guī)DLL自帶的DllMain函數(shù)中,有這么一些細(xì)節(jié),在下面的中文注釋中標(biāo)注
             1extern "C"
             2BOOL WINAPI InternalDllMain(HINSTANCE hInstance, DWORD dwReason, LPVOID /*lpReserved*/)
             3{
             4    if (dwReason == DLL_PROCESS_ATTACH)
             5    {
             6        
             7
             8        _AFX_THREAD_STATE* pState = AfxGetThreadState();
             9        //下面這句,保存了前一個(gè)模塊的module state。
            10        //但是如果前一個(gè)模塊是非MFC程序,那么pPrevModState=0
            11        AFX_MODULE_STATE* pPrevModState = pState->m_pPrevModuleState;
            12
            13        
            14
            15        // initialize the single instance DLL
            16        CWinApp* pApp; pApp = AfxGetApp();
            17        if (pApp != NULL && !pApp->InitInstance())
            18        {
            19            pApp->ExitInstance();
            20            AfxWinTerm();
            21            goto Cleanup;       // Init Failed
            22        }

            23
            24        
            25
            26        bResult = TRUE;
            27
            28Cleanup:
            29        pState->m_pPrevModuleState = pPrevModState;
            30#ifdef _AFXDLL
            31        // restore previously-saved module state
            32        //這里,在退出DllMain前,將module state的指針設(shè)置為0
            33        //以后AfxGetModuleState的值就是0了
            34        //這樣的情況下,MFC的很多方法和類根本無法使用
            35        VERIFY(AfxSetModuleState(AfxGetThreadState()->m_pPrevModuleState) ==
            36            &afxModuleState);
            37        DEBUG_ONLY(AfxGetThreadState()->m_pPrevModuleState = NULL);
            38#endif
            39        return bResult;
            40    }

            41    
            42    
            43
            44    return TRUE;
            45}

            由于我的調(diào)用程序不是MFC程序,所以MFC常規(guī)DLL中保存的module state值為0,當(dāng)構(gòu)造CFileDialog時(shí),相關(guān)的地方就失敗了。
            知道原因,就知道解決方法了。
            1.注意到DllMain恢復(fù)前一個(gè)module state的代碼,是寫在 #ifdef _AFXDLL里面的。也就是說,取消_AFXDLL的宏定義,module state的值就應(yīng)該是有效的。
            我將MFC常規(guī)DLL的編譯選項(xiàng)Use Of MFC 改為 Use MFC In a Static Library后重新編譯,執(zhí)行正常。

            2.第二個(gè)方法就是想辦法設(shè)置一個(gè)module state,比如可以用MFC常規(guī)DLL中的那個(gè)module state
             1BOOL Capp3App::InitInstance()
             2{
             3    CWinApp::InitInstance();
             4
             5    //在MFC DLL中保存module state
             6    g_ms = AfxGetModuleState();
             7
             8    return TRUE;
             9}

            10
            11
            12__declspec( dllexport ) void create_frm2()
            13{
            14    //剛進(jìn)來,這時(shí)候module state = 0
            15    //將它設(shè)置為一個(gè)有效值
            16    AfxSetModuleState( g_ms );
            17    
            18    CFileDialog dlg( TRUE );
            19    dlg.DoModal();
            20}

            3.第三個(gè)方法就是,把調(diào)用程序換成MFC程序,不過我不是很喜歡這樣
            posted on 2008-05-19 22:06 LOGOS 閱讀(2816) 評(píng)論(1)  編輯 收藏 引用

            FeedBack:
            # re: 使用MFC常規(guī)DLL 2008-05-21 20:07 編程的夜貓
            好啊,學(xué)習(xí)了。以后會(huì)注意的,感謝樓主  回復(fù)  更多評(píng)論
              

            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            亚洲中文字幕久久精品无码APP | 国产精品久久精品| 久久精品国产亚洲av水果派| 久久久久夜夜夜精品国产| 国产精品九九久久免费视频| 久久婷婷色香五月综合激情| 久久九九精品99国产精品| 99久久无码一区人妻| 无码日韩人妻精品久久蜜桃| 亚洲一区中文字幕久久| 久久精品国产亚洲AV不卡| 1000部精品久久久久久久久| 色天使久久综合网天天| 久久免费高清视频| 午夜天堂精品久久久久| 久久国产免费| 久久精品国产99国产电影网| 伊人久久大香线蕉AV一区二区 | 亚洲国产精品无码久久一区二区| 亚洲午夜精品久久久久久人妖| 久久综合亚洲鲁鲁五月天| 亚洲国产成人久久精品动漫| 亚洲国产精品无码久久久蜜芽 | 欧美大战日韩91综合一区婷婷久久青草| 人妻久久久一区二区三区| 亚洲国产精品无码久久青草| 久久九九亚洲精品| 久久99国产精品久久| 人妻无码αv中文字幕久久| 欧美日韩精品久久免费| 中文字幕久久亚洲一区| 国产女人aaa级久久久级| 热99re久久国超精品首页| av无码久久久久久不卡网站| 亚洲AV无一区二区三区久久| 久久婷婷五月综合成人D啪| 久久国产欧美日韩精品免费| 久久午夜免费视频| 中文字幕无码免费久久| 奇米影视7777久久精品| 蜜臀久久99精品久久久久久小说|