其格式一般爲: #Pragma Para
其中Para 爲參數,下面來看一些常用的參數。
(1)message 參數。 Message 參數能夠在編譯信息輸出窗口中輸出相應的信息,這對於源代碼信息的控制是非常重要的。其使用方法爲: #Pragma message(“消息文本”) 當編譯器遇到這條指令時就在編譯輸出窗口中將消息文本打印出來。 當我們在程序中定義了許多宏來控制源代碼版本的時候,我們自己有可能都會忘記有沒有正確的設置這些宏,此時我們可以用這條指令在編譯的時候就進行檢查。假設我們希望判斷自己有沒有在源代碼的什麼地方定義了_X86這個宏可以用下面的方法 #ifdef _X86 #Pragma message(“_X86 macro activated!”) #endif 當我們定義了_X86這個宏以後,應用程序在編譯時就會在編譯輸出窗口裏顯示“_X86 macro activated!”。我們就不會因爲不記得自己定義的一些特定的宏而抓耳撓腮了。
(2)另一個使用得比較多的pragma參數是code_seg。格式如: #pragma code_seg( ["section-name"[,"section-class"] ] ) 它能夠設置程序中函數代碼存放的代碼段,當我們開發驅動程序的時候就會使用到它。
(3)#pragma once (比較常用) 只要在頭文件的最開始加入這條指令就能夠保證頭文件被編譯一次,這條指令實際上在VC6中就已經有了,但是考慮到兼容性並沒有太多的使用它。 #pragma once是編譯相關,就是說這個編譯系統上能用,但在其他編譯系統不一定可以,也就是說移植性差,不過現在基本上已經是每個編譯器都有這個定義了。
(4)#pragma hdrstop表示預編譯頭文件到此爲止,後面的頭文件不進行預編譯。BCB可以預編譯頭文件以加快鏈接的速度,但如果所有頭文件都進行預編譯又可能佔太多磁盤空間,所以使用這個選項排除一些頭文件。 有時單元之間有依賴關係,比如單元A依賴單元B,所以單元B要先於單元A編譯。你可以用#pragma startup指定編譯優先級,如果使用了#pragma package(smart_init) ,BCB就會根據優先級的大小先後編譯。
(5)#pragma resource "*.dfm"表示把*.dfm文件中的資源加入工程。*.dfm中包括窗體外觀的定義。
(6)#pragma warning( disable : 4507 34; once : 4385; error : 164 ) 等價於: #pragma warning(disable:4507 34) // 不顯示4507和34號警告信息 #pragma warning(once:4385) // 4385號警告信息僅報告一次 #pragma warning(error:164) // 把164號警告信息作爲一個錯誤。 同時這個pragma warning 也支持如下格式: #pragma warning( push [ ,n ] ) #pragma warning( pop ) 這裏n代表一個警告等級(1---4)。 #pragma warning( push )保存所有警告信息的現有的警告狀態。 #pragma warning( push, n)保存所有警告信息的現有的警告狀態,並且把全局警告等級設定爲n。 #pragma warning( pop )向棧中彈出最後一個警告信息, 在入棧和出棧之間所作的一切改動取消。例如: #pragma warning( push ) #pragma warning( disable : 4705 ) #pragma warning( disable : 4706 ) #pragma warning( disable : 4707 ) //....... #pragma warning( pop ) 在這段代碼的最後,重新保存所有的警告信息(包括4705,4706和4707)。
(7)pragma comment(...) 該指令將一個註釋記錄放入一個對象文件或可執行文件中。 常用的lib關鍵字,可以幫我們連入一個庫文件 。 每個編譯程序可以用#pragma指令激活或終止該編譯程序支持的一些編譯功能。例如,對循環優化功能: #pragma loop_opt(on) // 激活 #pragma loop_opt(off) // 終止 有時,程序中會有些函數會使編譯器發出你熟知而想忽略的警告,如“Parameter xxx is never used in function xxx”,可以這樣: #pragma warn —100 // Turn off the warning message for warning #100 int insert_record(REC *r) { /* function body */ } #pragma warn +100 // Turn the warning message for warning #100 back on 函數會產生一條有唯一特徵碼100的警告信息,如此可暫時終止該警告。 每個編譯器對#pragma的實現不同,在一個編譯器中有效在別的編譯器中幾乎無效。可從編譯器的文檔中查看。 #pragma pack(n)和#pragma pack() struct sample { char a; double b; }; 當sample結構沒有加#pragma pack(n)的時候,sample按最大的成員那個對齊; (所謂的對齊是指對齊數爲n時,對每個成員進行對齊,既如果成員a的大小小於n則將a擴大到n個大小; 如果a的大小大於n則使用a的大小;)所以上面那個結構的大小爲16字節. 當sample結構加#pragma pack(1)的時候,sizeof(sample)=9字節;無空字節。 (另注:當n大於sample結構的最大成員的大小時,n取最大成員的大小。 所以當n越大時,結構的速度越快,大小越大;反之則) #pragma pack()就是取消#pragma pack(n)的意思了,也就是說接下來的結構不用#pragma pack(n)