错误处理 Error Reporting 头文件 errno.h volatile int errno; 当函数调用出现错误时,这个值会被设置成对应的错误码,可以根据错误码判断具体出现什么错误。
Error code
Error Message libc还提供了几个函数,可以将对应的错误码转换成用户能读懂的错误消息,现在来介绍这几个函数。
#include <string.h> char *strerror(int errno);该函数以errno作为参数,返回一个指向静态去错误消息的指针。因此该函数不是线程安全的。
例如:打开一个不存在的文件
#include <stdio.h> #include <errno.h> #include <string.h> int main(int argc, char **argv){ FILE *fp = fopen("aaaa.txt", "r"); if(fp == NULL){ fprintf(stderr, "%s\n", strerror(errno)); } if(fp) fclose(fp); return 0; }输出结果: $ ./a.out No such file or directory
#include <string.h> void perror(const char *messge);这个函数将错误消息输出到标准错误(stderr),所输出的消息跟strerror输出的错误消息相同,必须在函数执行完立即调用。 参数message可以为NULL,空字符串或自定义的错误消息。输出结果会自动添加换行符。
例如:
#include <stdio.h> #include <errno.h> #include <string.h> int main(int argc, char **argv){ FILE *fp = fopen("aaaa.txt", "r"); if(fp == NULL){ //fprintf(stderr, "%s\n", strerror(errno)); perror("open file error"); } if(fp) fclose(fp); return 0; }输出: $ ./a.out open file error: No such file or directory
#include <string.h> char * strerror_r (int errnum , char * buf , size t n );这个函数是gnu libc的扩展,这个功能跟strerror相同,只不过,它的消息不是放在静态存储区的,而是写到用户提供的buf中。这个函数是线程安全的。
例如:
#include <stdio.h> #include <string.h> #include <errno.h> #define BUF_LEN 1024 int main(int argc, char **argv){ char buf[BUF_LEN] = {0}; FILE *fp = fopen("xxxx.txt", "r"); if(fp == NULL){ (void)strerror_r(errno, buf, BUF_LEN); fprintf(stderr, "%s\n", buf); } if(fp) fclose(fp); return 0; }输出: $ ./a.out No such file or directory