• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            應(yīng)

            我們的工程馬上就要發(fā)布,但是在一個干凈的,即沒有安裝vs2005的xp上運行(利用虛擬機測試)卻彈出下面得錯誤
            “由于應(yīng)用程序配置不正確,應(yīng)用程序未能啟動。重新安裝應(yīng)用程序可能會糾正這個問題“
            在英文os上:
            This application has failed to start because the application configuration is incorrect. Reinstalling the application may fix this problem.
            考慮到程序的運行環(huán)境問題,可能是由于沒有安裝.netFrameWork.但是后來安裝上之后仍然如故。郁悶。。。
            在網(wǎng)上找出了這些方法:
            方法一:
            在類似C:\Program Files\Microsoft Visual Studio 8\VC\redi
            st\Debug_NonRedist\x86\Microsoft.VC80.DebugCRT 下找到了下列文件:
            msvcm80d.dll
            msvcp80d.dll
            msvcr80d.dll
            Microsoft.VC80.DebugCRT.manifest
            把這幾個文件拷貝到目標(biāo)機器上,與運行程序同一文件夾或放到system32下,就可以正確運行了。
            其他release版、MFC程序什么的都是拷redist下相應(yīng)文件夾下的文件就可以了,文件夾后都有標(biāo)識!
            方法二:
            修改編譯選項,將/MD或/MDd 改為 /MT或/MTd,這樣就實現(xiàn)了對VC運行時庫的靜態(tài)鏈接,在運行時就不再需要VC的dll了。
            注:MSDN中對于在不同的配置下Link的LIB作了說明:
            C Runtime Library:
            開關(guān) 對應(yīng)的庫 版本
            /MD MSVCRT.LIB 多線程DLL的Release版本
            /MDd MSVCRTD.LIB 多線程DLL的Debug版本
            /MT LIBCMT.LIB 多線程靜態(tài)鏈接的Release版本
            /MTd LIBCMTD.LIB 多線程靜態(tài)鏈接的Debug版本
            /clr MSVCMRT.LIB 托管代碼和非托管代碼混合
            /clr:pure MSVCURT.LIB 純托管代碼 
            C++ Standard Library:
            開關(guān) 對應(yīng)的庫 版本
            /MD MSVCPRT.LIB 多線程DLL的Release版本
            /MDd MSVCPRTD.LIB 多線程DLL的Debug版本
            /MT LIBCPMT.LIB 多線程靜態(tài)鏈接的Release版本
            /MTd LIBCPMTD.LIB 多線程靜態(tài)鏈接的Debug版本 
            編譯器會自動根據(jù)編譯選項,選擇對應(yīng)的LIB文件。一般情況下這不會出現(xiàn)問題。
            然而,在部分情況下,一旦你的程序的各個部分(LIB, OBJ…)并非由相同的編譯選項編譯出,而Link在一起的話,會出現(xiàn)各種各樣的看似很難解決的問題,這類問題主要以重復(fù)定義的錯誤形式存在,通常的解決方法也很簡單,就是選擇同樣的編譯選項進(jìn)行編譯之后再Link
            方法三:
            工程-》屬性-》配置屬性-》常規(guī)-》MFC的使用,選擇“在靜態(tài)庫中使用mfc”
            這樣生成的exe文件應(yīng)該就可以在其他機器上跑了。
            方法四:
            安裝vcredist_x86.exe

            這樣四步下來,大部分程序都應(yīng)該可以運行了,但悲哀的是在我的測試機上還是報應(yīng)用程序配置錯誤。無奈。。
            后打開vs2005的命令行,運行depends.exe,試圖找出程序啟動所依賴的dll,結(jié)果大失所望,虛擬機上這些dll都有。如此這般令人抓狂。
            最后把vs2005安裝目錄下的所有.manifest文件(可以搜索 *.manifest得到)都考到程序目錄下,程序奇跡般的可以運行。
            然后實驗,刪掉冗余的.manifest文件,只需要5個就夠了。它們是Microsoft.VC80.ATL.manifest
            Microsoft.VC80.CRT.manifest
            Microsoft.VC80.DebugCRT.manifest
            Microsoft.VC80.DebugMFC.manifest
            Microsoft.VC80.MFC.manifest

            Posted on 2009-11-10 13:58 micheal's tech 閱讀(876) 評論(0)  編輯 收藏 引用

            只有注冊用戶登錄后才能發(fā)表評論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            久久久久国色AV免费观看| 久久免费的精品国产V∧| 色综合久久综合中文综合网| 久久国产精品一区二区| 国内精品伊人久久久影院| 91久久成人免费| 久久人人爽人人爽人人片AV不| 日本国产精品久久| 国产成人无码精品久久久久免费 | 久久精品国产精品亚洲| 久久精品中文无码资源站| 精品久久久一二三区| 久久精品国产精品亚洲下载| 2021久久精品国产99国产精品| 精品久久人人爽天天玩人人妻| 午夜视频久久久久一区| 久久伊人精品青青草原日本| 品成人欧美大片久久国产欧美| 久久婷婷久久一区二区三区| 久久天天躁狠狠躁夜夜网站| 久久久久久国产精品免费无码| 伊人久久大香线蕉av一区| 久久国语露脸国产精品电影| 久久久这里有精品| 无码人妻久久一区二区三区蜜桃| 久久久中文字幕日本| 久久久久一本毛久久久| 开心久久婷婷综合中文字幕| 久久强奷乱码老熟女| 国产精品久久久久久久久久免费| 亚洲成人精品久久| 国产一区二区精品久久凹凸 | 久久国产香蕉视频| 久久无码AV中文出轨人妻| 一本大道久久东京热无码AV| 午夜精品久久久久| 亚洲精品乱码久久久久久中文字幕| 久久久久亚洲精品中文字幕| 亚洲国产成人久久一区WWW| 国内精品伊人久久久久777| 久久夜色精品国产噜噜亚洲AV|