您好,登錄后才能下訂單哦!
我們今天來講下 C 語言中的兩個比較偏僻的知識點,之所以說偏僻是因為在平時的代碼中我們見得很少。首先來說下 #error,它是用于生成一個編譯錯誤消息。用法如下:#error message;注意 message 不需要用雙引號包圍。#error 編譯指示字用于自定義程序員特有的編譯錯誤消息,類似的,#warning 就用于生成編譯警告的(但它可以編譯成功,生成可執(zhí)行文件)。
#error 是一種預(yù)編譯器指示字,可用于提示編譯條件是否滿足。那么在編譯過程中的任意錯誤信息意味著無法生成最終的可執(zhí)行程序,自定義的 #error 也是一樣。下來我們分析個示例代碼,代碼如下
#include <stdio.h> class CppClass { private: int m_value; public: CppClass() { } ~CppClass() { } }; int main() { return 0; }
我們看這段代碼,熟悉 C++ 的人,可能一眼就看出了這是一段 C++ 的代碼。在我們沒學(xué)習(xí)過 C++ 的前提下,我們用 C 的方式來編譯下,看看什么情況
顯然是報錯了,不認(rèn)識 class 的類型。那么我們在代碼一開始就加上下面的代碼進行說明這是段 C++ 的代碼,必須用 C++ 的編譯器才可以,編譯信息也就很明顯了。
#ifndef __cplusplus #error This file should be processed with C++ compiler. #endif
我們來看看編譯結(jié)果
圖中所指出的便是我們自己添加的 #error 信息了。下面箭頭所指的便是用 g++ 來編譯的,我們發(fā)現(xiàn)它成功編譯,并沒有出錯。
下面通過一個示例代碼來講講 #error 在項目工程中是怎樣進行應(yīng)用的
#include <stdio.h> void f() { #if ( PRODUCT == 1 ) printf("This is a low level product!\n"); #elif ( PRODUCT == 2 ) printf("This is a middle level product!\n"); #elif ( PRODUCT == 3 ) printf("This is a high level product!\n"); #else #error The 'PRODUCT' is NOT defined! #endif } int main() { f(); printf("1. Query Information.\n"); printf("2. Record Information.\n"); printf("3. Delete Information.\n"); #if ( PRODUCT == 1 ) printf("4. Exit.\n"); #elif ( PRODUCT == 2 ) printf("4. High Level Query.\n"); printf("5. Exit.\n"); #elif ( PRODUCT == 3 ) printf("4. High Level Query.\n"); printf("5. Mannul Service.\n"); printf("6. Exit.\n"); #else #error The 'PRODUCT' is NOT defined! #endif return 0; }
我們直接編譯,不加 -DPRODUCT,看看編譯后的結(jié)果
直接報錯,沒有定義 PRODUCT。那我們分別定義它為 1, 2, 3 將會輸出低,中,高版本的打印信息嗎?我們看看編譯結(jié)果
結(jié)果確實是如我們分析的那樣,分別打印出低,中,高版本的信息啦。
我們下面來講講 #line 的用法,它用于強制指定新的行號和編譯文件名,并對源程序的代碼進行重新編號。用法:#line number filename。ps:filename 可省略。#line 編譯指示字的本質(zhì)就是重新定義我們 C 語言中內(nèi)置的宏 __LINE__ 和 __FILE__。
我們來看個示例代碼,代碼如下
#include <stdio.h> int main() { printf("%s : %d\n", __FILE__, __LINE__); #line 1 "a.c" printf("%s : %d\n", __FILE__, __LINE__); return 0; }
我們分析下,在程序的第5行會打印出 test.c:5。那么我們在第7行使用了 #line 后,在程序的第9行就應(yīng)該打印出 a.c:2。我們來看看編譯結(jié)果
那么這種寫法有什么好處呢?在以前的開發(fā)中,為了加快開發(fā)速度,一個項目通常是由好幾個人共同完成。那么把所有人的代碼整合到一份代碼中,我們編譯的時候如果出錯,我們又怎么知道是誰的代碼出錯呢?這時就需要 #line 編譯指示字了。下面我們看看這個示例代碼
#include <stdio.h> // The code section is written by A. // Begin #line 1 "a.c" // End // The code section is written by B. // Begin #line 1 "b.c" // End // The code section is written by c. // Begin #line 1 "c.c" int main() { printf("%s : %d\n", __FILE__, __LINE__) return 0; } // End
我們注釋的代碼,程序員當(dāng)然看的懂,但是編譯器不認(rèn)識啊。這時我們就用 #line 指定后,編譯器就知道那塊代碼是誰寫的了,報錯當(dāng)然會報出來啦。我們故意在程序的第21行制造一個錯誤??纯淳幾g器能否報出來是誰的錯
它說在 c.c 中的第5行 return 前少一個 ;。我們再次加上之后編譯,如下
我們看到結(jié)果已經(jīng)正確。通過對 #error 和 #line 的學(xué)習(xí),總結(jié)如下:1、#error 用于自定義一條編譯錯誤信息,#waring 用于自定義一條編譯警告信息;2、#error 和 #warning 常應(yīng)用于條件編譯的情形;3、#line 用于強制指定新的行號和編譯文件名。
歡迎大家一起來學(xué)習(xí) C 語言,可以加我QQ:243343083。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。