您当前的位置:首页 > 计算机 > 编程开发 > C语言

C语言perror()函数:打印最近一次系统错误信息

时间:12-29来源:作者:点击数:

头文件:#include <stdio.h>

函数perror()用于抛出最近的一次系统错误信息,其原型如下:
    void perror(char *string);

【参数】string为要输出的错误信息。

说明:perror()用来将上一个函数发生错误的原因输出到标准错误(stderr)。参数string所指的字符串会先打印出,后面再加上错误原因字符串,此错误原因依照全局变量errno 的值来决定要输出的字符串。

在库函数中有个errno变量,每个errno值对应着以字符串表示的错误类型。当你调用"某些"函数出错时,该函数已经重新设置了errno的值。perror函数只是将你输入的一些信息和现在的errno所对应的错误一起输出。

【实例】打开一个不存在的文件并输出错误信息。

#include <stdio.h>
#include <assert.h>
#include <stdlib.h>
int main( void )
{
    FILE *fp;
    fp = fopen( "test.txt", "w" );/*打开文件*/
    assert( fp ); /*断言不为空*/
    fclose( fp );/*关闭*/
    fp = fopen( "nulltest.txt", "r" );/*打开一个不存在的文件*/
    if ( NULL == fp )
    {
        /*显示最近一次错误信息*/
        perror("fopen( \"nulltest.txt\", \"r\" )");
    }
    return 0;
}

运行结果:fopen( "nulltest.txt", "r" ):No such file or directory

程序先定义一个文件指针fp,之后创建文件 test.txt,断言文件打开成功,然后关闭该文件,再以只读的方式打开文件nulltest.txt,判断该文件指针是否问空,如果为空则使用 perror() 输出错误信息。perror()用来将上一个函数发生错误的原因 输出到标准设备(stderr)。函数参数string所指的字符串会先打印出, 后面再加上错误原因字符串。此错误原因依照全局变量error的值来决定要输出的字符串。

如果连续调用perror,如下:

perror("1");

perror("2");

会出现以下结果:

1:success

2:Illegal seek

这种问题出现的原因是:

perror()是通过lseek方法根据errorno查找对应的错误信息,然后输出的。

在程序运行的时候,errorno的初始值对应的信息为:Success。只有程序中有错误出现时,才会改变给errorno。如果没有错误出现,errorno的值是不会改变的。

但是perror方法是个例外,每次调用perror方法,都会首先输出errorno对应的信息,然后重置errorno为undefined,这时如果马上在一次调用perror,perror中的lseek根据undefined去查找错误信息,就会抛错,错误刚好被记录在errorno中,因此,就把lseek的错误打印出来了。所以第一次调用perror方法的时候会正常数据错误信息,但是如果连续调用第二次,由于第一次的perror调用已经把errorno设置成了undefined,所以连续的第二次,第三次...........第一亿次调用都会输出Illegal seek错误。

方便获取更多学习、工作、生活信息请关注本站微信公众号城东书院 微信服务号城东书院 微信订阅号
推荐内容
相关内容
栏目更新
栏目热门