【轉】fatal error C1853解決方法_lotus

當 Visual C++ 項目啓用了預編譯頭 (Precompiled header) 功能時,如果項目中同時混合有 .c 和.cpp 源文件,則可能收到 C1853 編譯器錯誤:fatal error C1853: 'pjtname.pch'precompiled header file is from a previous version of the compiler,or the precompiled header is C++ and you are using it from C (orvice versa)(致命錯誤C1853: “filename.pch”預編譯頭文件來自編譯器的早期版本,或者預編譯頭爲C++而在C 中使用它(或相反))。

該錯誤是因爲當項目中混合了 .cpp 和 .c文件時,編譯器會對它們採取不同的編譯方式(主要是因爲對函數聲明的處理方式不同),因而不能共用一個預編譯頭文件。在 VC++中,默認的預編譯頭文件是針對 C++ 的 (stdafx.h 和 stdafx.cpp),當然也可以創建針對 C的預編譯頭。有趣的是,在舊版的 VC++ 中,這個錯誤的提示很具有誤導性:fatal error C1853: 'xxx.pch'is not a precompiled header file created with this compiler.常常讓人摸不着頭腦。應該說,在新版中的這個提示是有所改進的。不過在網上搜索一番,對這個問題往往都是建議對整個項目取消預編譯頭的設置,這顯然不是一個好的解決方案。對於一個比較大的工程來說,使用預編譯頭可以使總的編譯時間大大減少。因而保留預編譯頭的設置纔是比較好的解決方案。搜索MSDN,針對不同的情況,可以有不同的解決方案:

本人是用方法1解決的

方案1:適用於絕大多數文件是 .cpp或絕大多數文件是.c的情況。在這種情況下,將少數的不同類文件設爲不使用預編譯頭是比較平衡的做法,方法是:對於 VC++6.0,在FileView 裏對要取消預編譯頭的 .c (或 .cpp) 文件點右鍵,選擇 settings,在彈出的對話框右邊選擇category 爲 precompiled headers,再設置選項爲 not using ...;(對於 VS2005,則在solution explorer 中對相應文件點右鍵選擇 properties,在 precompiled headers 項下設置not using... 即可。如果需要設置多個文件,則可以按住 Ctrl 鍵再同時選中這些文件並設置)PS:解釋如下點擊項目點擊屬性 然後選擇C/C++   預編譯頭 創建使用頭文件不使用預編譯頭文件(解決方案資源管理器-右擊需要排除的c或cpp文件]-彈出屬性菜單-展開C/C++-預編譯頭-創建/使用預編譯頭-選擇不適用預編譯頭)

方案2:影響的文件比較多,則把它們都設置禁止預編譯頭的話仍然會使項目總體的編譯速度大大降低,得不償失。這時考慮可以爲這組文件建立專用的預編譯頭。在VC++ 極早期版本(1.5及以前版本)中是支持單個工程中建立分別針對 .c 和 .cpp的預編譯頭的,但之後的版本中只支持單獨的預編譯頭。在這種情況下,我們可以在workspace(或solution)中建立一個新的靜態鏈接庫 (Static Library) 工程,將所有的 .c文件獨立出來加入到該工程中單獨編譯,這樣就可以在該靜態鏈接庫中針對 .c文件創建預編譯頭。但是這樣做在一定程度上需要被獨立出來的代碼在邏輯上是屬於同一模塊中的,這樣才便於維護。不過從設計的角度來說,這個要求一般是滿足的,否則就應考慮下項目的總體設計了:P最後別忘了設置原項目的依賴項 (dependency) 爲獨立出來的這個靜態庫項目。
 

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