MFC80.DLL复制到程序目录中,也有的说复制到安装目录中
在用VS2005學(xué)習(xí)C++調(diào)試程序的時(shí)候,按F5鍵,總提示這個(gè)問(wèn)題,
不曉得什么原因,網(wǎng)上有的說(shuō)找到MFC80.DLL復(fù)制到程序目錄中,也有的說(shuō)復(fù)制到安裝目錄中,可結(jié)果很失望,也有的VS2005安裝有問(wèn)題,系統(tǒng)有問(wèn)題等等。最后還是用以下方法解決了:
在“啟動(dòng)調(diào)試F5”的工具圖標(biāo)右側(cè)有一欄“解決方案配置”,將其中的“Debug”改為“Release”,
F5通過(guò),運(yùn)行正常,項(xiàng)目目錄下生成“Release”文件夾,Debug方式生成的“Debug"文件夾是無(wú)用的。原因:?
? DEBUG和RELEASE 版本差異及調(diào)試相關(guān)問(wèn)題:
? I. 內(nèi)存分配問(wèn)題
? 1. 變量未初始化。下面的程序在debug中運(yùn)行的很好。
????? thing * search(thing * something)
??????? BOOL found;
??????? for(int i = 0; i < whatever.GetSize(); i++)
????????? {
????????? if(whatever[i]->field == something->field)
???????????? { /* found it */
????????????? found = TRUE;
????????????? break;
???????????? } /* found it */
?????????? }
??? if(found)
???????????? return whatever[i];
??? else
???????????? return NULL;
? 而在release中卻不行,因?yàn)閐ebug中會(huì)自動(dòng)給變量初始化found=FALSE,而在release版中則不會(huì)。所以盡可能的給變量、類或結(jié)構(gòu)初始化。
? 2.數(shù)據(jù)溢出的問(wèn)題
??????? 如:char buffer[10];
???????????? int counter;
?????? lstrcpy(buffer, "abcdefghik");
? 在debug版中buffer的NULL覆蓋了counter的高位,但是除非counter>16M,什么問(wèn)題也沒(méi)有。但是在release版中,counter可能被放在寄存器中,這樣NULL就覆蓋了buffer下面的空間,可能就是函數(shù)的返回地址,這將導(dǎo)致ACCESS ERROR。
? 3.DEBUG版和RELEASE版的內(nèi)存分配方式是不同的。如果你在DEBUG版中申請(qǐng)?? ele 為 6*sizeof(DWORD)=24bytes,實(shí)際上分配給你的是32bytes(debug版以32bytes為單位分配),而在release版,分配給你的就是24bytes(release版以8bytes為單位),所以在debug版中如果你寫ele[6],可能不會(huì)有什么問(wèn)題,而在release版中,就有ACCESS VIOLATE。
? II.ASSERT和VERIFY
? 1.ASSERT在Release版本中是不會(huì)被編譯的。
? ASSERT宏是這樣定義的
??????? #ifdef _DEBUG
??????? #define ASSERT(x) if( (x) == 0) report_assert_failure()
??????? #else
??????? #define ASSERT(x)
??????? #endif
??????? 實(shí)際上復(fù)雜一些,但無(wú)關(guān)緊要。假如你在這些語(yǔ)句中加了程序中必須要有的代碼
? 比如
? ASSERT(pNewObj = new CMyClass);
? pNewObj->MyFunction();
? 這種時(shí)候Release版本中的pNewObj不會(huì)分配到空間
? 所以執(zhí)行到下一個(gè)語(yǔ)句的時(shí)候程序會(huì)報(bào)該程序執(zhí)行了非法操作的錯(cuò)誤。這時(shí)可以用VERIFY :
??????? #ifdef _DEBUG
??????? #define VERIFY(x) if( (x) == 0) report_assert_failure()
?
?
? #else
??????? #define VERIFY(x) (x)
??????? #endif
? 這樣的話,代碼在release版中就可以執(zhí)行了。
? III.參數(shù)問(wèn)題:
? 自定義消息的處理函數(shù),必須定義如下:
? afx_msg LRESULT OnMyMessage(WPARAM, LPARAM);
? 返回值必須是HRESULT型,否則Debug會(huì)過(guò),而Release出錯(cuò)
? IV.內(nèi)存分配
? 保證數(shù)據(jù)創(chuàng)建和清除的統(tǒng)一性:如果一個(gè)DLL提供一個(gè)能夠創(chuàng)建數(shù)據(jù)的函數(shù),那么這個(gè)DLL同時(shí)應(yīng)該提供一個(gè)函數(shù)銷毀這些數(shù)據(jù)。數(shù)據(jù)的創(chuàng)建和清除應(yīng)該在同一個(gè)層次上。
? V.DLL的災(zāi)難
? 人們將不同版本DLL混合造成的不一致性形象的稱為 “動(dòng)態(tài)連接庫(kù)的地獄“(DLL Hell) ,甚至微軟自己也這么說(shuō)(http://msdn.microsoft.com/library/techart/dlldanger1.htm)。如果你的程序使用你自己的DLL時(shí)請(qǐng)注意:
? 1.不能將debug和release版的DLL混合在一起使用。debug都是debug版,release版都是release版。解決辦法是將debug和release的程序分別放在主程序的debug和release目錄下
? 2.千萬(wàn)不要以為靜態(tài)連接庫(kù)會(huì)解決問(wèn)題,那只會(huì)使情況更糟糕。
? VI.RELEASE板中的調(diào)試:
? 1.將ASSERT() 改為 VERIFY() 。找出定義在"#ifdef _DEBUG"中的代碼,如果在RELEASE版本中需要這些代碼請(qǐng)將他們移到定義外。查找TRACE(...)中代碼,因?yàn)檫@些代碼在RELEASE中也不被編譯。請(qǐng)認(rèn)真檢查那些在RELEASE中需要的代碼是否并沒(méi)有被便宜。
? 2.變量的初始化所帶來(lái)的不同,在不同的系統(tǒng),或是在DEBUG/RELEASE版本間都存在這樣的差異,所以請(qǐng)對(duì)變量進(jìn)行初始化。
? 3.是否在編譯時(shí)已經(jīng)有了警告?請(qǐng)將警告級(jí)別設(shè)置為3或4,然后保證在編譯時(shí)沒(méi)有警告出現(xiàn).
? VII.將Project Settings" 中 "C++/C " 項(xiàng)目下優(yōu)化選項(xiàng)改為Disbale(Debug)。編譯器的優(yōu)化可能導(dǎo)致許多意想不到的錯(cuò)誤,請(qǐng)參考http://www.pgh.net/~newcomer/debug_release.htm
? 1.此外對(duì)RELEASE版本的軟件也可以進(jìn)行調(diào)試,請(qǐng)做如下改動(dòng):
? 在"Project Settings" 中 "C++/C " 項(xiàng)目下設(shè)置 "category" 為 "General" 并且將"Debug Info"設(shè)置為 "Program Database"。在 "Link"項(xiàng)目下選中"Generate Debug Info"檢查框。"Rebuild All" 如此做法會(huì)產(chǎn)生的一些限制:無(wú)法獲得在MFC DLL中的變量的值。必須對(duì)該軟件所使用的所有DLL工程都進(jìn)行改動(dòng)。
? 另:
? MS BUG:MS的一份技術(shù)文檔中表明,在VC5中對(duì)于DLL的"Maximize Speed"優(yōu)化選項(xiàng)并未被完全支持,因此這將會(huì)引起內(nèi)存錯(cuò)誤并導(dǎo)致程序崩潰。
? 2.www.sysinternals.com有一個(gè)程序DebugView,用來(lái)捕捉OutputDebugString的輸出,運(yùn)行起來(lái)后(估計(jì)是自設(shè)為system debugger)就可以觀看所有程序的OutputDebugString的輸出。此后,你可以脫離VC來(lái)運(yùn)行你的程序并觀看調(diào)試信息。
? 3.有一個(gè)叫Gimpel Lint的靜態(tài)代碼檢查工具,據(jù)說(shuō)比較好用。http://www.gimpel.com/ 不過(guò)要化$的。
總結(jié)
以上是生活随笔為你收集整理的MFC80.DLL复制到程序目录中,也有的说复制到安装目录中的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 微软研发致胜策略
- 下一篇: error C2440 “static_