解析#pragma命令<二>

   #pragma 預處理   在全部的預處理指令中,#Pragma 指令多是最複雜的了,它的做用是設定編譯器的狀態或者是指示編譯器完成一些特定的動做。#pragma指令對每一個編譯器給出了一個方法,在保持與C和C++語言徹底兼容的狀況下,給出主機或操做系統專有的特徵。依據定義,編譯指示是機器或操做系統專有的,且對於每一個編譯器都是不一樣的。   其格式通常爲: #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中就已經有了,可是考慮到兼容性並無太多的使用它。   (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的實現不一樣,在一個編譯器中有效在別的編譯器中幾乎無效。可從編譯器的文檔中查看。
相關文章
相關標籤/搜索