系统调用的错误处理

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风格。

posted on 2014-02-28 10:41  奇好猫  阅读(613)  评论(0编辑  收藏  举报

导航