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