文章編號: 126717 - 上次校閱: 2005年7月5日 - 版次: 1.1

PRB: C1853 錯誤由混合 C 和 C + + 檔案產生

系統提示本文適用於您使用的作業系統之外的作業系統。與您不相關的文章內容已停用。

在此頁中

全部展開 | 全部摺疊

徵狀

當您在建置 Visual C++ 專案,包括 C 和 C + + 檔案以及所使用先行編譯標頭可能會收到下列錯誤訊息:
嚴重錯誤 C1853: '<filename>' 不是先行編譯標頭檔
使用這個編譯器建立

發生的原因

編譯器會嘗試使用 C 原始程式檔上的 C + + 編譯器所產生的先行編譯標頭。"每次檔案使用的先行編譯標頭檔 」 搭配 C 和 C + + 專案中的原始程式碼時,就可能發生這種情況。

無效使用 C + + 編譯器建立先行編譯標頭 (帶有是由 C 編譯器編譯的來源檔案。也不能有效使用 C 編譯器則以 C + + 編譯器所編譯的來源檔案方式建立先行編譯標頭。

在 Visual C++ 版本 2.x 錯誤訊息的說明 C1853 可能容易讓人誤解。 這表示只在混合.PCH 檔案以 16 位元和 32 位元編譯器產生時,會發生問題。經常,但是時,就會發生這個問題將 C 原始程式檔加入至單純的 C + + 專案,使用"每次檔案使用的先行編譯標頭"之後建置專案。(Visual C++ 4.0 版線上說明正確地結合此資訊所指出 C1853"可能因 C 程式碼中使用先行編譯的 C + + 檔 」 該嚴重錯誤)。

解決方案

可以解決這個問題,這種情況而定的幾種方式:

解析度我

為單一的 C 原始程式檔和多個 C + + 來源檔案 (或相反) 專案,使用下列步驟來停用單一的原始程式檔的先行編譯標頭:

  1. 目前目標的開啟專案設定] 對話方塊,並選取 [C/C + +] 索引標籤下的 [先行編譯標頭檔] 區段。
  2. 從專案樹狀結構,在左窗格中選取 C 的檔案。
  3. Visual C++ 版本 2.x 停用 [每檔案使用的先行編譯標頭檔中的 [使用.PCH 檔案] 核取方塊。Visual C++ 版本 4.0、 5.0 和 6.0,選取 [未使用先行編譯標頭選項按鈕。
  4. 儲存新的設定,並建置專案。

解析度 II

對於多個 C 和 C + + 原始程式檔的專案,使用下列步驟來停用先行編譯標頭一組的來源檔案程序:

與 Visual C++ 版本 2.x

  1. 目前目標建立新群組從 [專案] 功能表項目中選擇 [新增群組。
  2. 將 C 原始程式檔移至新的群組。
  3. 開啟專案設定,並選取先行編譯標頭區段的 [C/C + +] 索引標籤] 對話方塊。
  4. 從專案樹狀結構,在左窗格中選取新的群組。
  5. 停用 [.PCH 檔案使用核取方塊中先行將每檔案使用的編譯標頭檔。
  6. 儲存新的設定,並建置專案。
這將會停用一組的來源檔案的先行編譯標頭。但是,後續加入此群組的項目中的原始程式檔可能需要根據上檔案的先前的設定停用之 PCH 使用量。

與 Visual C++ 4.0 版,群組不再受到支援。若要停用群組的原始程式檔的先行編譯標頭使用,請遵循步驟的解析度我,但在步驟 2 中按住 CRTL 鍵,同時選取每個檔案。

解析度三世

對於不需要先行編譯標頭的專案依照解析度我,但在步驟 2 選取所有目標從專案樹狀結構,在左窗格中。

解析度 IV (VC 4.x 及 5.0)

  1. 建立型別的子專案 」 靜態程式庫 」。
  2. 這個子專案中插入.C 檔案。
  3. 從最上層專案中刪除.C 檔案。
  4. 將產生之程式庫或.obj 檔案加到最上層專案的連結線。
這可讓您指定先行編譯標頭的最上層專案 (.CPP 檔案) 和子專案 (.C 檔案) 不同的先行編譯標頭。

狀況說明

這種行為是經過設計規劃的。

其他相關資訊

Visual C++ 2.0 版可以讓每個目標專案中只能有一個先行編譯標頭檔。這個檔案會命名 PROJNAME.PCH 預設 PROJNAME 其中是專案的名稱。這可在專案選項編輯控制項的目標設定使用/Fp 選項 / (比方說 「 Fp MYNAME.PCH") 中變更。

C/C + +] 索引標籤] 對話方塊的專案設定] 的 [先行編譯標頭檔] 區段中所示,使用 [自動] 或 [每次檔案使用的系統可能會產生這個先行編譯標頭 (.PCH) 檔。

當目前.PCH 檔案無效或標頭檔更新時,自動 PCH 選項 (/ YX 選項) 會產生.PCH 檔案。無效的.PCH 檔案包括那些由另一個的編譯器 (C 或 C + +),或那些包含將用在來源中找到的不同組的標頭檔所產生。這個選項最佳狀態儲存編譯時間,如果所有使用這個選項的原始程式檔包含標頭檔的相同集合,而是一種類型 (C 或 C + +),或如果只在專案中的一個檔案通常已內建。

這個選項的效率可以編譯順序而定。永遠交錯編譯順序中的 C 和 C + + 原始程式檔會重新產生新的.PCH 檔案。建置專案在上次建置導致 C + +.PCH 檔案時更新 C 檔案之後,就會重新產生.PCH 檔案。

只要在編譯原始程式檔與 '.PCH 檔案建立 ' (/ Yc 選項)] 核取方塊已啟用,每檔案使用 PCH] 選項就會產生.PCH 檔案。有 '使用.PCH 檔案' (/ Yu 選項) 核取方塊已啟用的所有原始程式檔用於產生的.PCH 檔案。編譯器不會重新產生新的.PCH 檔,如果產生的一個無效 ; 而是,讓其中下列兩個訊息:
  • 如果 PCH 由 C + + 編譯器產生的:
    嚴重錯誤 C1853: '<filename>' 不是使用這個編譯器建立的先行編譯標頭檔
  • 如果 PCH 由包含一組不同的原始程式碼產生包括:
    嚴重錯誤 C1852: '<filename>' 不是有效的先行編譯標頭檔
注意: 可能指定多個來源來建立一個.PCH 檔案,不過 Microsoft 建議您不要它。也不會 Microsoft 建議您混合兩個 PCH 系統,因為混合使用兩個可能會導致上述的錯誤。

舊版的 Visual C++ (1.51、 1.50 和 1.1 版) 允許獨立的先行編譯標頭檔對於 C 和 C + + 原始程式檔。因為 Visual C++ 2.0 版限制為只有一個 PCH 所以就不可能使用不同的先行編譯標頭檔對於 C 和 C + + 檔。 當您嘗試建置專案時透過移植這類專案將會產生下列訊息:
來源檔案"file1.c"和 file2.cpp 」 兩者都設定為
產生輸出檔 proj.pch 」。無法建置專案。

?考

如需先行編譯標頭的詳細資訊,請搜尋在線上叢書 》 中的"先行編譯標頭 」。

這篇文章中的資訊適用於:
  • Microsoft Visual C++ 2.0 Professional Edition
  • Microsoft Visual C++ 2.1
  • Microsoft Visual C++ 4.0 Standard Edition
  • Microsoft Visual C++ 5.0 Enterprise Edition
  • Microsoft Visual C++ 5.0 Professional Edition
  • Microsoft Visual C++ 6.0 Enterprise Edition
  • Microsoft Visual C++ 6.0 Professional Edition
  • Microsoft Visual C++, 32-bit Learning Edition 6.0
關鍵字:?
kbmt kbcompiler kbcpponly kberrmsg kbprb KB126717 KbMtzh
機器翻譯機器翻譯
重要:本文是以 Microsoft 機器翻譯軟體翻譯而成,而非使用人工翻譯而成。Microsoft 同時提供使用者人工翻譯及機器翻譯兩個版本的文章,讓使用者可以依其使用語言使用知識庫中的所有文章。但是,機器翻譯的文章可能不盡完美。這些文章中也可能出現拼字、語意或文法上的錯誤,就像外國人在使用本國語言時可能發生的錯誤。Microsoft 不為內容的翻譯錯誤或客戶對該內容的使用所產生的任何錯誤或損害負責。Microsoft也同時將不斷地就機器翻譯軟體進行更新。
按一下這裡查看此文章的英文版本:126717? (http://support.microsoft.com/kb/126717/en-us/ )
Microsoft及(或)其供應商不就任何在本伺服器上發表的文字資料及其相關圖表資訊的恰當性作任何承諾。所有文字資料及其相關圖表均以「現狀」供應,不負任何擔保責任。Microsoft及(或)其供應商謹此聲明,不負任何對與此資訊有關之擔保責任,包括關於適售性、適用於某一特定用途、權利或不侵權的明示或默示擔保責任。Microsoft及(或)其供應商無論如何不對因或與使用本伺服器上資訊或與資訊的實行有關而引起的契約、過失或其他侵權行為之訴訟中的特別的、間接的、衍生性的損害或任何因使用而喪失所導致的之損害、資料或利潤負任何責任。