1. 程式人生 > >VS執行程式提示系統找不到路徑問題

VS執行程式提示系統找不到路徑問題

本人使用下列方法加清理專案,重新生成
4. 既然問題是在更新嵌入的清單檔案時發生的,由於FAT32的原因而未能更新嵌入的清單檔案,於是我們有如下兩種解決方法:
    (1)不啟用增量連結。在專案的“屬性|配置屬性|連結器|常規”中的“啟用增量連結”選擇“否”。此方法阻斷了問題產生的源頭,其每次生成exe檔案時都直接嵌入清單檔案,而不是預設的根據時戳而決定是否更新清單檔案。
    (2)不嵌入清單檔案。在專案的“屬性|配置屬性|清單工具|輸入和輸出”中的“嵌入清單”選擇“否”,從而在生成exe檔案時附隨生成一個清單檔案(預設情況下,其檔名為exe檔案的全名加上“.manifest”),避免了嵌入清單檔案可能失敗的問題。在程式執行時,會用到該清單檔案。顯然,這種方式使可執行程式產生了更多的外部依賴,不推薦。

VS 2010在生成可執行檔案時使用了一種新的技術,該技術生成的可執行檔案會伴隨生成一個清單檔案(manifest file)(.manifest字尾檔案)(其本質上是XML文件,你可以用文字編輯器開啟看看),並在連結完成後將該清單檔案嵌入到exe檔案中(預設情況下)。而在FAT32檔案系統中,在處理清單檔案階段,當增量連結時不能完成清單檔案的更新(預設情況下),於是造成清單檔案嵌入失敗,從而使該exe檔案執行時沒有相應的清單檔案而執行失敗並提示如上錯誤。
    解決方案很多,列舉如下:
    1. 由於這是在連結動態執行庫出現的問題,所以你可以選擇程式碼生成的連線方式為/MTd而非/MDd,不用這些DLL檔案從而避免問題的出現。該方法有一個很顯然的缺點:適用範圍有限,不推薦該方法。
    2. 既然跟FAT32系統有關,那麼我們可以選擇在NTFS檔案系統中開發從而避免該問題,此方法同上,也是採用的迴避問題的方式,不提倡。
    3. 該方法仍與FAT32有關:在專案的“屬性|配置屬性|清單工具|常規”中的“使用FAT32解決辦法”選擇“是”(預設為“否”),重新生成專案即可解決問題。該方法是唯一真正針對問題所在而提出的解決方法,使清單工具可以正確更新。(此方法是官方解決方法,也比較方便,推薦)
    4. 既然問題是在更新嵌入的清單檔案時發生的,由於FAT32的原因而未能更新嵌入的清單檔案,於是我們有如下兩種解決方法:
    (1)不啟用增量連結。在專案的“屬性|配置屬性|連結器|常規”中的“啟用增量連結”選擇“否”。此方法阻斷了問題產生的源頭,其每次生成exe檔案時都直接嵌入清單檔案,而不是預設的根據時戳而決定是否更新清單檔案。
    (2)不嵌入清單檔案。在專案的“屬性|配置屬性|清單工具|輸入和輸出”中的“嵌入清單”選擇“否”,從而在生成exe檔案時附隨生成一個清單檔案(預設情況下,其檔名為exe檔案的全名加上“.manifest”),避免了嵌入清單檔案可能失敗的問題。在程式執行時,會用到該清單檔案。顯然,這種方式使可執行程式產生了更多的外部依賴,不推薦。

    另外,還有一個不能稱為方法的土辦法:每次Build前手動刪除*.ilk檔案(增量連結檔案)(當然可以在專案屬性中寫入刪除命令,使其自動執行),不推薦該土辦法。
    最後,總結一下:
    1. 此問題只在特定條件下才會出現:在FAT32檔案系統中編譯、預設設定(增量模式、不啟用FAT32解決方案、嵌入清單檔案)、非第一次生成可執行檔案檔案(即在增量連線、更新清單檔案時)。
    2. 解決方案1和4.1方便實用,推薦使用。