C語言-基礎(chǔ)教程-C語言的預(yù)處理程序與注釋

字號:

C程序的源代碼中可包括各種編譯指令,這些指令稱為預(yù)處理命令。雖然它們實際上不是C語言的一部分,但卻擴展了C程序設(shè)計的環(huán)境。本節(jié)將介紹如何應(yīng)用預(yù)處理程序和注釋簡化程序開發(fā)過程,并提高程序的可讀性。
    4.7.1C語言的預(yù)處理程序
    ANSI標準定義的C語言預(yù)處理程序包括下列命令:
    #define
    #error
    #include
    #if
    #else
    #elif
    #endif
    #ifdef
    #ifndef
    #undef
    #line
    #pragma
    非常明顯,所有預(yù)處理命令均以符號#開頭,下面分別加以介紹。
    4.7.2#define
    命令#define定義了一個標識符及一個串。在源程序中每次遇到該標識符時,均以定義的串代換它。ANSI標準將標識符定義為宏名,將替換過程稱為宏替換。命令的一般形式為:
    #define identifier sing
    注意,該語句沒有分號。在標識符和串之間可以有任意個空格,串一旦開始,僅由一新行結(jié)束。
    例如,如希望TURE取值1,F(xiàn)ALSE取值0,可說明兩個宏#define
    #define TURE 1
    #define FALSE 0
    這使得在源程序中每次遇到TURE或FALSE就用0或1代替。
    例如,在屏幕上打印“012”:
    printf("%d%d%d",F(xiàn)ALSE,TRUE,TRUE 1);
    宏名定義后,即可成為其它宏名定義中的一部分。例如,下面代碼定義了ONE、TWO及THREE的值。
    #define ONE 1
    #define TWO ONE ONE
    #define THREE ONE TWO
    懂得宏替換僅僅是以串代替標識符這點很重要。因此,如果希望定義一個標準錯誤信息,可編寫如下代碼:
    #defineE_MS"standard error on input\n"
    printf(E_MS);
    編譯程序遇到標識符E_MS時,就用“standard error on input\n”替換。對于編譯程序,printf()語句實際是如下形式:
    printf("standard error on input\n;")
    如果在串中含有標識符,則不進行替換。例如:
    #define XYZ this is a test
    .
    .
    .
    printf("XYZ");
    該段不打印"this is a test"而打印"XYZ"。
    如果串長于一行,可以在該行末尾用一反斜杠續(xù)行,例如:
    #defineLONG_STRING"this is a very long\
    sing that is used as an example"
    C語言程序普遍使用大寫字母定義標識符。這種約定可使人讀程序時很快發(fā)現(xiàn)哪里有宏替換。是將所有的#define放到文件的開始處或獨立的文件中(用#include訪問),而不是將它們分散到整個程序中。
    宏代換的最一般用途是定義常量的名字和程序中的“游戲數(shù)”。例如,某一程序定義了一個數(shù)組,而它的幾個子程序要訪問該數(shù)組,不應(yīng)直接以常量定數(shù)組大小,是用名字定義之(需改變數(shù)組大小時)。
    #define MAX_SIZE100
    float balance [MAX_SIZE;]
    #define命令的另一個有用特性是,宏名可以取參量。每次遇到宏名時,與之相連的形參均由程序中的實參代替。例如:
    當編譯該程序時,由MIN(a,b)定義的表達式被替換,x和y用作操作數(shù),即printf()語句被代換后取如下形式:
    printf("the minimum is:%,d"(x    用宏代換代替實在的函數(shù)的一大好處是宏替換增加了代碼的速度,因為不存在函數(shù)調(diào)用的開銷。但增加速度也有代價:由于重復(fù)編碼而增加了程序長度。
    4.7.3#error
    處理器命令#error強迫編譯程序停止編譯,主要用于程序調(diào)試。