错误处理 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