今天編譯完CEGUI后運行時提示我缺少MSVCP80D.DLL,搜了下找到了解決方案 備忘.
在VS 2005中建立Win32工程時(以VS 2005中文版為例),你可能會遇到這樣的運行錯誤:“沒有找到MSVCP80D.dll,因此這個應(yīng)用程序未能啟動。重新安裝應(yīng)用程序可能會修復(fù)此問題。”(還可能是其它幾個類似的文件:MSVCR80D.dll、MSVCM80D.dll)。對于VS2005新手,可能遇到的第一個問題便是此問題。
一直使用VC6進行開發(fā)測試,最近準備把平臺轉(zhuǎn)移到VS2005(過些天就應(yīng)該轉(zhuǎn)VS2008了,呵呵)上來。于是,決定先把CppUnit轉(zhuǎn)移到此平臺上來。在VS2005中編譯CppUnit所遇到的問題不多,雖然沒VC6方便。但是在測試編譯好的CppUnit庫時卻遇到了困難:把以前在VC6中寫的AES移植過來(其使用了CppUnit進行單元測試),在運行時卻遇到了如上錯誤。剛開始以為可能是CppUnit沒有編譯好,重新編譯CppUnit多次,調(diào)整編譯參數(shù),但始終有此錯誤,并且此錯誤有時出現(xiàn)有時不出現(xiàn),這更暈了,大量時間就這樣浪費了。等我靜下來,才覺得可能是VS 2005的原因,于是上網(wǎng)搜索此錯誤信息,終于找到了問題所在。
VS 2005在生成可執(zhí)行文件時使用了一種新的技術(shù),該技術(shù)生成的可執(zhí)行文件會伴隨生成一個清單文件(manifest
file)(.manifest后綴文件)(其本質(zhì)上是XML文檔,你可以用文本編輯器打開看看),并在鏈接完成后將該清單文件嵌入到exe文件中(默認情況下)。而在FAT32文件系統(tǒng)中,在處理清單文件階段,當增量鏈接時不能完成清單文件的更新(默認情況下),于是造成清單文件嵌入失敗,從而使該exe文件運行時沒有相應(yīng)的清單文件而運行失敗并提示如上錯誤。
解決方案很多,列舉如下:
1. 由于這是在鏈接動態(tài)運行庫出現(xiàn)的問題,所以你可以選擇代碼生成的連接方式為/MTd而非/MDd,不用這些DLL文件從而避免問題的出現(xiàn)。該方法有一個很顯然的缺點:適用范圍有限,并且也不是我等提倡的解決問題的方式,不推薦該方法。
2. 既然跟FAT32系統(tǒng)有關(guān),那么我們可以選擇在NTFS文件系統(tǒng)中開發(fā)從而避免該問題,此方法同上,也是采用的回避問題的方式,不為我等提倡。
3. 該方法仍與FAT32有關(guān):在項目的“屬性|配置屬性|清單工具|常規(guī)”中的“使用FAT32解決辦法”選擇“是”(默認為“否”),重新生成項目即可解決問題。該方法是唯一真正針對問題所在而提出的解決方法,使清單工具可以正確更新。(此方法是官方解決方法,也比較方便,推薦)
4. 既然問題是在更新嵌入的清單文件時發(fā)生的,由于FAT32的原因而未能更新嵌入的清單文件,于是我們有如下兩種解決方法:
(1)不啟用增量鏈接。在項目的“屬性|配置屬性|鏈接器|常規(guī)”中的“啟用增量鏈接”選擇“否”。此方法阻斷了問題產(chǎn)生的源頭,其每次生成exe文件時都直接嵌入清單文件,而不是默認的根據(jù)時戳而決定是否更新清單文件。
(2)不嵌入清單文件。在項目的“屬性|配置屬性|清單工具|輸入和輸出”中的“嵌入清單”選擇“否”,從而在生成exe文件時附隨生成一個清單文件(默認情況下,其文件名為exe文件的全名加上“.manifest”),避免了嵌入清單文件可能失敗的問題。在程序運行時,會用到該清單文件。顯然,這種方式使可執(zhí)行程序產(chǎn)生了更多的外部依賴,不推薦。
另外,還有一個不能稱為方法的土辦法:每次Build前手動刪除*.ilk文件(增量鏈接文件)(當然可以在項目屬性中寫入刪除命令,使其自動執(zhí)行),不推薦該土辦法。
最后,總結(jié)一下:
1. 此問題只在特定條件下才會出現(xiàn):在FAT32文件系統(tǒng)中編譯、默認設(shè)置(增量模式、不啟用FAT32解決方案、嵌入清單文件)、非第一次生成可執(zhí)行文件文件(即在增量連接、更新清單文件時)。
2. 解決方案1和4.1方便實用,推薦使用。
今天編譯程序的時候,總是提示LINK : fatal error LNK1000: Internal error during IncrBuildImage
后在網(wǎng)上找到達人的解釋說,可以下載補丁解決(覺得不靠譜),或者只要“修改鏈接選項,方法:項目-屬性-鏈接器-常規(guī) 下面的“啟用增量鏈接”,將“是(/INCREMENTAL)”改為“否(/INCREMENTAL:NO)”,然后確定就可以了解決了”,試了下,果然可以。
可是我還是不知道增量是什么東東,又搜了下,在愛問上找到了答案:
現(xiàn)在的VS2003,2005,2009有增量編譯功能,就是如果你的代碼改動了,他們是不完全重新編譯整個代碼的,而是只編譯你所更改的部分。 出現(xiàn)這個提示,
1.你是第一次進行編譯,這時當然沒有生成過可執(zhí)行文件,也就無法增量鏈接了。
2.你上一次編譯的時候有錯誤,沒有生成可執(zhí)行文件。
posted on 2011-01-28 13:41
風(fēng)輕云淡 閱讀(414)
評論(0) 編輯 收藏 引用 所屬分類:
日常問題