对于库函数,特别是那些与操作系统有关的,当执行失败时会通过一个名称为error的外部变量,通知程序该函数调用失败,下面的代码利用这一特性进行错误处理:
/*调用库函数*/
if(erron)
/*处理错误*/
不幸的是这个是错误的,原因在于,在库函数调用没有失败的情况下,并没有强制要求库函数一定要设置errjon为0,这样erron的值就可能是前一个执行失败的库函数的值,下面是一个改良的代码
erron=0;
/*调用库函数*/
if(erron)
/*处理错误*/
这样好像能过工作,可惜还是错的,库函数在调用成功时并没有强制要求对erron清0,但同时也没有禁止设置errno。既然库函数已经调用成功,为什么还有可能设置errno呢?对于一些复杂的库函数(就是在这个库函数的执行过程中可能会调用其他库函数来完成它的一部分功能),比如fopen函数,当fopen函数被要求新建一个文件以供程序输出是,如果已经存在一个同名文件,fopen函数将先删除它,然后新建一个文件。这样,fopen函数可能需要调用其他库函数,以检测同名文件是否已经存在。(假设用于检测文件存在与否的函数在文件不存在时,会设置errno。)那么fopen函数每次新建一个事先并不存在的文件时,即使没有任何程序错误发生,errno也仍然可能被设置。
因此在调用库函数时,我们应该首先检测作为错误提示的返回值,确定程序执行已经失败。然后再检查errno,来搞清楚出错原因:
erron=0;
/*调用库函数*/
if(返回的错误值)
检测 errno