系统调用的错误处理
UNIX系统中,系统调用后要进行错误检查。若系统调用出错,典型的会返回-1,同时设置全局整数变量errno来表示什么出错了。
有些人会忽略错误检查,因为它们使代码变得臃肿,而且难以读懂。下面是UNIX fork函数的错误检查。
if( ( pid = fork() ) < 0){ fprintf( stderr, "fork error: %s\n", strerror( errno )); exit(0); }
通过定义下面的错误报告函数(error-reporting function),可在某种程度上简化代码。
void unix_error(char *msg) { fprintf(stderr, "%s: %s\n", msg, strerror(errno)); exit(0); }
给定这个函数,fork的调用可从4行简化为2行:
if ( (pid = fork() ) ) unix_error("fork error");
通过调用错误处理封装(error handling warpper),还可以进一步简化:
pid_t Fork() { pid_t pid; if( (pid = fork() ) < 0 ){ unix_error("Fork error"); exit(0); } return pid; }
Fork函数将fork的首字母大写,表示错误处理封装的函数,该函数的参数和返回值与fork相同,并调用基本函数,检查错误,如果有问题就终止。
这样优化后的错误检查,可以保持代码简洁,而又不会给人错误的假象,认为允许忽略错误检查。
不同时间、不同用途的函数可能有不同风格的报告函数,如unix风格、Posix风格以及DNS风格。