轉自:http://blog.csdn.net/waterathena/archive/2009/04/20/4094771.aspx
重裝系統之后,開發環境進行重新配置了。因為之前那個環境用了大概有半年多了,所以只是基本的配置作了記錄,其他細節的東西并沒有以文字方式記錄下來。這次運行起來有了一些未遇到過的問題。
問題1:重裝系統之前就遇到過,解決了。主要原因缺少DLL
問題描述:項目組要提交0.9版到QT部門進行測試,打包發布文件之后,在測試部測試電腦上安裝之后,發現雙擊.EXE不能運行。彈出信息框:由于應用程序配置不正確,應用程序未能啟動。重新安裝應用程序可能會糾正這個問題。
解決方法:當時網上一查發現需要拷貝VS2005安裝包目錄下的一些DLL文件。我的安裝目錄是:C:\Program Files\Microsoft Visual Studio 8\VC\redist\x86。我把這個目錄下的所有相關文件都拷貝到項目生成文件目錄下。
參考原文:http://www.cnblogs.com/wuhanhoutao/archive/2008/01/09/1031928.html
問題2:在重新安裝系統,重新安裝開發環境之后,工作了幾日后,發布新的版本給QT測試部門測試。發現又出現這樣的問題。主要原因MANIFEST不正確
問題描述:安裝完成之后,點擊.exe不能運行。彈出信息框:由于應用程序配置不正確,應用程序未能啟動。重新安裝應用程序可能會糾正這個問題。
其中有一次彈出的信息框為英文操作系統下面的信息:The application has failed to start because its side-by side configuration is incorrect.
正是這個信息里面的“side-by-side configuration”讓我去了解WINSXS。
參考文章:http://microsoft.cnfan.net/vista/3434.html (vista WinSxS 混亂導致的應用程序不能啟動 )
參考文章:http://blog.csdn.net/arau_sh/archive/2008/12/17/3538252.aspx (提供四種解決方法)
參考文章:http://hi.baidu.com/freedomknightduzhi/blog/item/60a5012e512bba554fc226e9.html
參考文章:http://www.cnblogs.com/holly/archive/2009/02/20/1395150.html (可以嘗試)
參考文章:http://blog.csdn.net/newweapon/archive/2008/06/17/2556857.aspx
官方參考資料:http://msdn.microsoft.com/en-us/library/dd408052(VS.85).aspx
參考文章:http://blogs.msdn.com/suzcook/archive/2004/05/14/132022.aspx (APP.CONFIG example)
我的解決方法:
1.我試驗了在測試目標機上安裝VC++ 2005 Redistribute package,.exe可以正確運行。但是我覺得這個并不能代表真正原因,因為之前我也沒有安裝任何發布包,但是.exe可以正確運行。
2.參考文章“vista WinSxS 混亂導致的應用程序不能啟動 ”可以知道,.exe在運行的時候執行的進程去系統默認路徑尋找需要的DLL文件,而沒有使用拷貝到本目錄下的DLL文件。所以如果系統沒有安裝發布套件,那么執行的時候就出現了“應用程序配置不正確……”的錯誤。
該文章中提供的解決方案把MANIFEST文件不要內嵌到.EXE文件中,調整編譯設置后我重新編譯了程序,然后拷貝程序到目標測試機測試,發現還是不行。這個時候我去查看了編譯生成在外部的MANIFEST文件(用文本文件可以打開MANIFEST)文件,發現了問題:
仔細一看就發現同樣的DLL寫了兩次,只是版本不同。而我拷貝到執行文件同目錄下的版本為8.0.50727.762。把最后那個dependency分支去掉后,在把執行文檔所在的整個目錄拷貝到QT目標測試機就運行起來了。
題外話:
1.在上面的參考文章中提到使用靜態鏈接MFC庫的形式,就不會出現這樣的問題。但是靜態鏈接庫不好,另外也會造成編譯生成的.EXE龐大。
如果實在沒有辦法的情況下,也只能靜態編譯了。設置順序為:Project->Properties(ALT+F7)->Property Page->General->Project Defaults->use of MFC設置:USE MFC IN A STATIC LIBRARY
然后BUILD。
2.在目標測試機上安裝相應的發布套件。VC_REDIST_X86.EXE
需要把官方發布的安裝套件和你的程序捆綁安裝,很麻煩。需要判斷操作系統(32or64位),需要判斷操作系統當前使用語言,然后安裝對應的版本。這是一定能解決不能運行的問題的辦法。
Microsoft Visual C++ 2005 Redistributable Package (x64) 下載地址:
http://www.microsoft.com/downloads/details.aspx?displaylang=zh-cn&FamilyID=90548130-4468-4bbc-9673-d6acabd5d13b
Microsoft Visual C++ 2005 Redistributable Package (x86)
http://www.microsoft.com/downloads/details.aspx?familyid=32BC1BEE-A3F9-4C13-9C99-220B62A191EE&displaylang=zh-cn
3. 如何查看本機的.NET Framework版本
參考文章:http://blog.csdn.net/FantasiaX/archive/2008/05/17/2453907.aspx
我喜歡的方法:從注冊表里查
注冊表其實就是一個大型的“鍵-值對列表”(Key-Value Pair List)。注冊表中的鍵是以樹狀層級結構記錄的,所以圖標看起來像是一個“文件夾”;一個鍵下,可以有“值”,而可以有再下一級的鍵。值是有數據類型的,比如字符串型、數字型;每個值都有自己的“Value Name”和“Value Data”。所以:
如果:HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\NET Framework Setup\NDP\v2.0.50727鍵下Value Name為Install的值的Value Data等于1,則說明.NET Framework 2.0.50727已經安裝。同理,檢查HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\NET Framework Setup\NDP\v3.0鍵和HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\NET Framework Setup\NDP\v3.5鍵下的Install值的Value Data就知道是否安裝了這兩個版本。我估計,如果沒有安裝過3.0和3.5的話,這兩個鍵是不會存在的,如果安裝后又卸載了,鍵可能會在,Install的Value Data可能會是0。
本文來自CSDN博客,轉載請標明出處:http://blog.csdn.net/waterathena/archive/2009/04/20/4094771.aspx