很多库函数,特别是那些与操作系统有关的库函数,当执行失败时会通过一个名称为errno 的外部变量,通知程序该函数调用失败。下面的代码利用这一特性进行错误处理,似乎再清楚明白不过,然而却是错误的:
/*调用库函数*/
if (errno)
/*处理错误*/
出错的原因在于,在库函数调用没有失败的情况下,并没有强制要求库函数一定要设errno为0,这样errno的值就可能是前个执行失败的库函数设置的值。下面的代码做了更正,
似乎能够工作,但可惜还是错误的:
errno = 0;
/* 调用库函数*/
if(errno)
/*处理错误*/
库函数在调用成功时,既没有强制要求对errno清零,同时也没有禁止设置errno。既然库函数已经调用成功,为什么还有可能设置errno呢?要理解这一点,我们不妨假想一下库函数fopen在调用时可能会发生什么情况。当fopen函数被要求新建一个文件以供程序输出时, 如果已经存在一个同名文件,fopen函数将先删除它,然后新建一个文件。这样,fopen函数可能需要调用其他的库函数,以检测同名文件是否已经存在(假设用于检测文件的库函数在文件不存在时,会设置errno。那么,fopen 函数每次新建一个事先并不存在的文件时,即使没有任何程序错误发生,也仍然可能设置errno。
因此,在调用库函数时,我们应该首先检测作为错误指示的返回值,确定程序执行已经失败,然后再检查errmo,来搞清楚出错原因:
/* 调用库函数*/
if(返回的错误值)
检查errno
版权声明:本文为shanhejieshiwo原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。