應用程序配置不正確,程序無法啓動的問題小結

重裝系統之後,開發環境進行重新配置了。因爲之前那個環境用了大概有半年多了,所以只是基本的配置作了記錄,其他細節的東西並沒有以文字方式記錄下來。這次運行起來有了一些未遇到過的問題。

問題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。

NetFrameReg

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章