引發(fā)了錯(cuò)誤,估計(jì)是我刪除了編譯的文件,但是沒(méi)有刪除干凈,結(jié)果再次編譯的時(shí)候,出錯(cuò)了.
Project->C/C++->Precompiled Header,只要選擇:Not Using? Precompiled Headers,就萬(wàn)事大吉了=.=
預(yù)編譯頭文件的使用:
?
關(guān)鍵字:預(yù)編譯,/Yu,/Yc,/Yx
本文介紹VC6的預(yù)編譯功能的使用,由于預(yù)編譯詳細(xì)使用比較的復(fù)雜,這里只介紹幾個(gè)最重要的預(yù)編譯指令: /Yu, /Yc,/Yx,/Fp。其它的詳細(xì)資料可以參考:
MSDN->Visual Studio D6.0Document -> Visual C++6.0 Document
->VC++ Programer Guider ->Compiler and Linker
->Details->Creating Precompiled Header files
預(yù)編譯頭的概念:
所謂的預(yù)編譯頭就是把一個(gè)工程中的那一部分代碼,預(yù)先編譯好放在一個(gè)文件里(通常是以.pch為擴(kuò)展名的),這個(gè)文件就稱為預(yù)編譯頭文件這些預(yù)先編譯好的代碼可以是任何的C/C++代碼--------甚至是inline的函數(shù),但是必須是穩(wěn)定的,在工程開(kāi)發(fā)的過(guò)程中不會(huì)被經(jīng)常改變。如果這些代碼被修改,則需要重新編譯生成預(yù)編譯頭文件。注意生成預(yù)編譯頭文件是很耗時(shí)間的。同時(shí)你得注意預(yù)編譯頭文件通常很大,通常有6-7M大。注意及時(shí)清理那些沒(méi)有用的預(yù)編譯頭文件。
也許你會(huì)問(wèn):現(xiàn)在的編譯器都有Time stamp的功能,編譯器在編譯整個(gè)工程的時(shí)候,它只會(huì)編譯那些經(jīng)過(guò)修改的文件,而不會(huì)去編譯那些從上次編譯過(guò),到現(xiàn)在沒(méi)有被修改過(guò)的文件。那么為什么還要預(yù)編譯頭文件呢?答案在這里,我們知道編譯器是以文件為單位編譯的,一個(gè)文件經(jīng)過(guò)修改后,會(huì)重新編譯整個(gè)文件,當(dāng)然在這個(gè)文件里包含的所有頭文件中的東西(.eg Macro, Preprocesser )都要重新處理一遍。VC的預(yù)編譯頭文件保存的正是這部分信息。以避免每次都要重新處理這些頭文件。
預(yù)編譯頭的作用:
方法一:手動(dòng)方法
根據(jù)上文介紹,預(yù)編譯頭文件的作用當(dāng)然就是提高便宜速度了,有了它你沒(méi)有必要每次都編譯那些不需要經(jīng)常改變的代碼。編譯性能當(dāng)然就提高了。
預(yù)編譯頭的使用:
???? 要使用預(yù)編譯頭,我們必須指定一個(gè)頭文件,這個(gè)頭文件包含我們不會(huì)經(jīng)常改變的代碼和其他的頭文件,然后我們用這個(gè)頭文件來(lái)生成一個(gè)預(yù)編譯頭文件(.pch文件)
?想必大家都知道 StdAfx.h這個(gè)文件。很多人都認(rèn)為這是VC提供的一個(gè)“系統(tǒng)級(jí)別”的,編譯器帶的一個(gè)頭文件。其實(shí)不是的,這個(gè)文件可以是任何名字的。我們來(lái)考察一個(gè)典型的由AppWizard生成的MFC Dialog Based 程序的預(yù)編譯頭文件。(因?yàn)?/span>AppWizard會(huì)為我們指定好如何使用預(yù)編譯頭文件,默認(rèn)的是StdAfx.h,這是VC起的名字)。我們會(huì)發(fā)現(xiàn)這個(gè)頭文件里包含了以下的頭文件:
#include <afxwin.h>???????? // MFC core and standard components
#include <afxext.h>???????? // MFC extensions
#include <afxdisp.h>??????? // MFC Automation classes
#include <afxdtctl.h>???????????? // MFC support for Internet Explorer 4 Common Controls
#include <afxcmn.h>?????
這些正是使用MFC的必須包含的頭文件,當(dāng)然我們不太可能在我們的工程中修改這些頭文件的,所以說(shuō)他們是穩(wěn)定的。
那么我們?nèi)绾沃付ㄋ鼇?lái)生成預(yù)編譯頭文件。我們知道一個(gè)頭文件是不能編譯的。所以我們還需要一個(gè)cpp文件來(lái)生成.pch 文件。這個(gè)文件默認(rèn)的就是StdAfx.cpp。在這個(gè)文件里只有一句代碼就是:#include “Stdafx.h”。原因是理所當(dāng)然的,我們僅僅是要它能夠編譯而已―――也就是說(shuō),要的只是它的.cpp的擴(kuò)展名。我們可以用/Yc編譯開(kāi)關(guān)來(lái)指定StdAfx.cpp來(lái)生成一個(gè).pch文件,通過(guò)/Fp編譯開(kāi)關(guān)來(lái)指定生成的pch文件的名字。打開(kāi)project ->Setting->C/C++ 對(duì)話框。把Category指向Precompiled Header。在左邊的樹(shù)形視圖里選擇整個(gè)工程 (如圖)
(圖1)
在圖中我們的Project Options(右下角的那個(gè)白的地方)可以看到 /Fp “debug/PCH.pch”,這就是指定生成的.pch文件的名字,默認(rèn)的通常是 <工程名>.pch(我的示例工程名就是PCH)。
然后,在左邊的樹(shù)形視圖里選擇StdAfx.cpp.如圖:(圖2)
這時(shí)原來(lái)的Project Option變成了 Source File Option(原來(lái)是工程,現(xiàn)在是一個(gè)文件,當(dāng)然變了)。在這里我們可以看到 /Yc開(kāi)關(guān),/Yc的作用就是指定這個(gè)文件來(lái)創(chuàng)建一個(gè)Pch文件。/Yc后面的文件名是那個(gè)包含了穩(wěn)定代碼的頭文件,一個(gè)工程里只能有一個(gè)文件的可以有YC開(kāi)關(guān)。VC就根據(jù)這個(gè)選項(xiàng)把 StdAfx.cpp編譯成一個(gè)Obj文件和一個(gè)PCH文件。
?? 然后我們?cè)龠x擇一個(gè)其它的文件來(lái)看看,如圖:
?????
在這里,Precomplier 選擇了 Use ………一項(xiàng),頭文件是我們指定創(chuàng)建PCH 文件的stdafx.h
文件。事實(shí)上,這里是使用工程里的設(shè)置,(如圖1)/Yu”stdafx.h”。
?? 這樣,我們就設(shè)置好了預(yù)編譯頭文件。也就是說(shuō),我們可以使用預(yù)編譯頭功能了。以下是注意事項(xiàng):
1):如果使用了/Yu,就是說(shuō)使用了預(yù)編譯,我們?cè)诿總€(gè).cpp文件的最開(kāi)頭,我強(qiáng)調(diào)一遍是最開(kāi)頭,包含你指定產(chǎn)生pch文件的.h文件(默認(rèn)是stdafx.h)不然就會(huì)有問(wèn)題。如果你沒(méi)有包含這個(gè)文件,就告訴你Unexpected file end. 如果你不是在最開(kāi)頭包含的,你自己試以下就知道了,絕對(duì)有很驚人的效果…..
2)如果你把pch文件不小心丟了,編譯的時(shí)候就會(huì)產(chǎn)生很多的不正常的行為。根據(jù)以上的分析,你只要讓編譯器生成一個(gè)pch文件。也就是說(shuō)把 stdafx.cpp(即指定/Yc的那個(gè)cpp文件)從新編譯一遍。當(dāng)然你可以傻傻的 Rebuild All。簡(jiǎn)單一點(diǎn)就是選擇那個(gè)cpp文件,按一下Ctrl + F7就可以了。不然可是很浪費(fèi)時(shí)間的哦。
方法二。自動(dòng)使用
很簡(jiǎn)單只要指定/YX就可以了。或者在上圖中選擇Automatic………就可以了。注意的事情是如果你指定了/Yc /Yu的話,/Yx是會(huì)被忽略的。前者的優(yōu)先級(jí)別高一些。
???????
????????????????????????????????????????????????? 潘李亮? 2002 9