On The Road
(cond ((less 'code) (less 'bug)))
C++博客
首頁
新隨筆
聯系
聚合
管理
隨筆 - 119 文章 - 290 trackbacks - 0
博客搬家了哦,請移步
叫我abc
常用鏈接
我的隨筆
我的評論
我參與的隨筆
留言簿
(12)
給我留言
查看公開留言
查看私人留言
隨筆分類
《GAME PROGRAMMING GEMS6》讀書筆記(4)
《UNIX編程藝術》讀書筆記(4)
month-flow(5)
mysql入門(3)
垃圾收集(4)
我的博客
叫我abc
博客搬家啦
搜索
積分與排名
積分 - 304364
排名 - 84
最新評論
1.?re: C++ std::fstream open mode
i'am got
--hdj
2.?re: cppcheck的使用
你好,你會使用cppcheck嗎?@robert
--wqq
3.?re: 垃圾收集的那點事(H)
非常感謝
--7Qing_
4.?re: 高效調用lua函數
為什么提示沒有findLuaItem這個函數?
--sdfasf
5.?re: android ndk調試知識[未登錄]
博主你好,請問如果沒有.so的源代碼,應該如何進行arm的匯編級調試呢?
--dennis
閱讀排行榜
1.?cppcheck的使用(17027)
2.?十步精通新語言(10669)
3.?內存池實現(9887)
4.?高效調用lua函數(9238)
5.?在lua腳本中使用unicode(8217)
使用MFC常規DLL
最近知道可以使用MFC常規DLL導出一些功能,交給其他程序使用,即使那個程序不是MFC程序。
嘗試的環境大概是這樣的,MFC常規DLL,以及普通的控制臺程序。
MFC常規DLL的一個導出函數
1
__declspec( dllexport )
void
create_frm2()
2
{
3
CFileDialog dlg( TRUE );
4
dlg.DoModal();
5
}
調用導出函數的應用程序
1
int
_tmain(
int
argc, _TCHAR
*
argv[])
2
{
3
create_frm2();
4
5
return
0
;
6
}
不過在嘗試的過程中,出了點問題,在調用導出函數的時候不是崩潰就是大量的DEBUG ASSERT,看起來卡在CFileDialog的構造函數上了。
請教同事,才知道大概緣由。
在MFC常規DLL自帶的DllMain函數中,有這么一些細節,在下面的中文注釋中標注
1
extern
"
C
"
2
BOOL 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
//
下面這句,保存了前一個模塊的module state。
10
//
但是如果前一個模塊是非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
28
Cleanup:
29
pState
->
m_pPrevModuleState
=
pPrevModState;
30
#ifdef _AFXDLL
31
//
restore previously-saved module state
32
//
這里,在退出DllMain前,將module state的指針設置為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
}
由于我的調用程序不是MFC程序,所以MFC常規DLL中保存的module state值為0,當構造CFileDialog時,相關的地方就失敗了。
知道原因,就知道解決方法了。
1.注意到DllMain恢復前一個module state的代碼,是寫在 #ifdef _AFXDLL里面的。也就是說,取消_AFXDLL的宏定義,module state的值就應該是有效的。
我將MFC常規DLL的編譯選項Use Of MFC 改為 Use MFC In a Static Library后重新編譯,執行正常。
2.第二個方法就是想辦法設置一個module state,比如可以用MFC常規DLL中的那個module state
1
BOOL 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
//
剛進來,這時候module state = 0
15
//
將它設置為一個有效值
16
AfxSetModuleState( g_ms );
17
18
CFileDialog dlg( TRUE );
19
dlg.DoModal();
20
}
3.第三個方法就是,把調用程序換成MFC程序,不過我不是很喜歡這樣
posted on 2008-05-19 22:06
LOGOS
閱讀(2827)
評論(1)
編輯
收藏
引用
FeedBack:
#
re: 使用MFC常規DLL
2008-05-21 20:07
編程的夜貓
好啊,學習了。以后會注意的,感謝樓主
回復
更多評論
刷新評論列表
只有注冊用戶
登錄
后才能發表評論。
【推薦】100%開源!大型工業跨平臺軟件C++源碼提供,建模,組態!
網站導航:
博客園
IT新聞
BlogJava
博問
Chat2DB
管理
Copyright ©2025 LOGOS Powered by:
博客園
模板提供:
滬江博客
久久丝袜精品中文字幕
|
青草影院天堂男人久久
|
亚洲日本久久久午夜精品
|
久久精品一本到99热免费
|
久久香蕉国产线看观看精品yw
|
亚洲伊人久久成综合人影院
|
亚洲国产成人乱码精品女人久久久不卡
|
色欲综合久久中文字幕网
|
91精品日韩人妻无码久久不卡
|
久久精品国产99久久无毒不卡
|
狠狠综合久久综合88亚洲
|
国产成人精品久久二区二区
|
亚洲欧美久久久久9999
|
久久se精品一区精品二区
|
久久人做人爽一区二区三区
|
久久久久久久99精品免费观看
|
精品多毛少妇人妻AV免费久久
|
国产成人综合久久精品尤物
|
久久综合给久久狠狠97色
|
久久99这里只有精品国产
|
亚洲午夜精品久久久久久人妖
|
久久精品国产网红主播
|
精品国产日韩久久亚洲
|
手机看片久久高清国产日韩
|
国产精久久一区二区三区
|
国产精品久久影院
|
99久久婷婷国产综合亚洲
|
亚洲AV日韩精品久久久久久久
|
欧美精品福利视频一区二区三区久久久精品
|
精品久久无码中文字幕
|
色欲综合久久中文字幕网
|
亚洲AV成人无码久久精品老人
|
伊人色综合九久久天天蜜桃
|
色综合合久久天天给综看
|
久久青青国产
|
日本亚洲色大成网站WWW久久
|
色播久久人人爽人人爽人人片AV
|
国产精品狼人久久久久影院
|
国产精品欧美亚洲韩国日本久久
|
久久精品国产精品青草app
|
99久久免费国产精品热
|