初步理解异常控制流中调用fork函数和wait函数的错误处理
在计算机系统中,异常有中断、陷阱、故障和终止四种类别,具体的内容我们不在此处展开,但是无论如何,当异常出现时,计算机系统都会对其进行处理, 其大致流程如下图所示:
作为初学者,我们平常练习时所编写的代码其实是极为朴素简单的,在代码中加入进行错误处理也不会导致程序难以阅读。但实际上,我们日常生活、工作生产中使用的大部分程序其实都是非常复杂的。
当Unix系统级函数遇到错误时,它们通常会返回-1,并设置全局整数变量errno来表示什么出错了。程序员应该总是检查错误,但是不幸的是,许多人都忽略了错误检查,因为它使代码变得臃肿,而且难以读懂。比如,下面是我们调用Unix fork函数时会如何检查错误:
if ((pid = fork()) <0){
fprintf(stderr, "fork error: %s\n",strerror(errno)) ;
exit(0) ;
}
strerror函数返回一个文本串,描述了和某个errno值相关联的错误。通过定义下面的错误报告函数,我们能够在某种程度上简化这个代码:
void unix_error(char *msg)/ * Unix-style error */{
fprintf(stderr,"%s: %s\n", msg,strerror(errno));
exit(0);
}
给定这个函数,我们对fork的调用从4行缩减到2行: