C語言邊角料4:利用_Pragma來溫柔的廢棄API
-
一、前言
-
二、操作過程
-
三、 _Prama 其他用法
一、前言
想象一下這個(gè)工作場(chǎng)景:你在為一個(gè)項(xiàng)目寫一個(gè)功能庫(kù),別人調(diào)用庫(kù)中提供的函數(shù),后來你發(fā)現(xiàn)庫(kù)里的函數(shù)A是多余的。
二、操作過程
1. 第一個(gè)版本的庫(kù)
測(cè)試文件只有 3 個(gè):api.h, api.c 和 main.c
api.h 文件內(nèi)容:聲明了 2 個(gè)函數(shù)。
- api.h 和 api.c: 庫(kù)文件,編譯得到 libapi.so;
- main.c:生成可執(zhí)行程序,利用了上面生成的庫(kù) libapi.so;
main.c 文件內(nèi)容:
以上代碼的簡(jiǎn)單程度,等價(jià)于 helloworld 了。
2. 第二個(gè)版本的庫(kù)
現(xiàn)在,你覺得 init 這個(gè)函數(shù)是多余的,想把它去掉,可以這么來修改。
既然 api.c 文件已經(jīng)把這個(gè)函數(shù)刪除了,但是 main.c 文件中又調(diào)用了這個(gè)函數(shù),因此以宏定義的形式提供 init 這個(gè)符號(hào)。
(1) 是在宏替換時(shí)的表達(dá)式。因?yàn)檫@個(gè)函數(shù)可能被用在 if 條件判斷中,因此需要返回一個(gè)值。在編譯可執(zhí)行文件時(shí),編譯器輸出下面的這段話:
API_DEPRECATED 是另一個(gè)宏定義,擴(kuò)展開來后就是讓編譯器在編譯可執(zhí)行程序時(shí),打印出一段提示信息。
這樣就達(dá)到了最初的目的!也就是提示使用者:這個(gè)函數(shù)已經(jīng)被廢棄了,最好別用它!
三 _Prama 其他用法
_Pragma 類似于 Microsoft 特定的 __pragma 關(guān)鍵字,只不過它是標(biāo)準(zhǔn)的一部分。它是在 C99 中為 C 引入的。對(duì)于 c ,它是在 c 11 中引入的。它允許將指令放入宏定義中。
1. 處理頭文件重復(fù)包含
在頭文件中,為了防止被重復(fù)包含,一般有 3 種處理方式:
// 頭文件內(nèi)容
#endif
(2) 第二種處理方式
// 頭文件內(nèi)容
以上這 2 種方式都可以防止同一個(gè)頭文件被重復(fù)包含,但是還是有一些區(qū)別的。
這種方式與第二種方式的區(qū)別是:
#pragma :是一條預(yù)處理的指令,用來向編譯器傳達(dá)語言標(biāo)準(zhǔn)以外的一些信息,不能使用在宏中;#pragma 是編譯器的擴(kuò)展,也就是說它是由編譯器來決定的,也許編譯器A支持,但是編譯器B就不一定支持了,雖然這種可能性比較小。
_Pragma :是一個(gè)操作符,屬于語言的標(biāo)準(zhǔn),因此可以嵌套在宏中,就像上面示例中那樣;
2. 輸出編譯信息
上面兩行的內(nèi)容輸出信息是一樣的,需要注意的是嵌套的雙引號(hào)需要用反斜線去轉(zhuǎn)義。