C 語言不提供對錯誤處理的直接支持,但是作為一種系統編程語言,它以返回值的形式允許您訪問底層數據。在發生錯誤時,大多數的 C 或 UNIX 函數調用返回 1 或 NULL,同時會設置一個錯誤代碼errno,該錯誤代碼是全局變量,表示在函數調用期間發生了錯誤。
您可以在 errno.h 頭文件中找到各種各樣的錯誤代碼。
所以,C 程序員可以通過檢查返回值,然后根據返回值決定采取哪種適當的動作。開發人員應該在程序初始化時,把 errno 設置為 0,這是一種良好的編程習慣。0 值表示程序中沒有錯誤。
errno、perror() 和 strerror()
C 語言提供了perror()和strerror()函數來顯示與errno相關的文本消息。
perror()函數顯示您傳給它的字符串,后跟一個冒號、一個空格和當前 errno 值的文本表示形式。
strerror()函數,返回一個指針,指針指向當前 errno 值的文本表示形式。
讓我們來模擬一種錯誤情況,嘗試打開一個不存在的文件。您可以使用多種方式來輸出錯誤消息,在這里我們使用函數來演示用法。另外有一點需要注意,您應該使用stderr文件流來輸出所有的錯誤。
#include#include #include extern int errno ; int main () { FILE * pf; int errnum; pf = fopen ("unexist.txt", "rb"); if (pf == NULL) { errnum = errno; fprintf(stderr, "錯誤號: %d ", errno); perror("通過 perror 輸出錯誤"); fprintf(stderr, "打開文件錯誤: %s ", strerror( errnum )); } else { fclose (pf); } return 0; }
當上面的代碼被編譯和執行時,它會產生下列結果:
錯誤號: 2 通過 perror 輸出錯誤: No such file or directory 打開文件錯誤: No such file or directory
被零除的錯誤
在進行除法運算時,如果不檢查除數是否為零,則會導致一個運行時錯誤。
為了避免這種情況發生,下面的代碼在進行除法運算前會先檢查除數是否為零:
#include#include main() { int dividend = 20; int divisor = 0; int quotient; if( divisor == 0){ fprintf(stderr, "除數為 0 退出運行... "); exit(-1); } quotient = dividend / divisor; fprintf(stderr, "quotient 變量的值為 : %d ", quotient ); exit(0); }
當上面的代碼被編譯和執行時,它會產生下列結果:
除數為 0 退出運行...
程序退出狀態
通常情況下,程序成功執行完一個操作正常退出的時候會帶有值 EXIT_SUCCESS。在這里,EXIT_SUCCESS 是宏,它被定義為 0。
如果程序中存在一種錯誤情況,當您退出程序時,會帶有狀態值 EXIT_FAILURE,被定義為 -1。所以,上面的程序可以寫成:
#include#include main() { int dividend = 20; int divisor = 5; int quotient; if( divisor == 0){ fprintf(stderr, "除數為 0 退出運行... "); exit(EXIT_FAILURE); } quotient = dividend / divisor; fprintf(stderr, "quotient 變量的值為: %d ", quotient ); exit(EXIT_SUCCESS); }
當上面的代碼被編譯和執行時,它會產生下列結果:
quotient 變量的值為 : 4
審核編輯:劉清
-
C語言
+關注
關注
180文章
7632瀏覽量
141674 -
編程語言
+關注
關注
10文章
1956瀏覽量
36635 -
函數調用
+關注
關注
0文章
19瀏覽量
2674
原文標題:C語言中的錯誤處理機制
文章出處:【微信號:單片機與嵌入式,微信公眾號:單片機與嵌入式】歡迎添加關注!文章轉載請注明出處。
發布評論請先 登錄
Rust語言中錯誤處理的機制
LabVIEW中的錯誤處理
C++異常機制解析

評論