关于errno的判断

errno的判断

很多库函数,特别是那些与操作系统相关的,当执行失败时,需要对errno的值进行判断,判断程序是否执行失败。下面的代码利用对errno的判断,进行错误处理,似乎在清楚明白不过了,然而这却是错误的!

/* 库函数调用 */
if(errno)
{
    /* 错误处理 */
}

出错原因在于,在库函数调用没有失败的情况下,并没有强制要求库函数一定要设置errno为0,这样errno的值就可能是前一个执行失败的库函数设置的值。下面的代码更正了一下,似乎能够工作,可惜还是错误的!

errno = 0;

/* 库函数调用 */
if(errno)
{
    /*错误处理*/
}

库函数调在调用成功时,既没有强制要求对errno清零,但同时也没有禁止设置errno。既然库函数已经调用成功,为什么还有可能设置errno呢?

要理解这一点,我们不妨假设一下库函数fopen在调用时可能会发生的情况。当fopen函数被要求新建一个文件以供程序输出时,如果已经存在一个同名文件,fopen函数先将删除它,然后新建一个文件。这样,fopen函数可能需要调用其他的库函数,以检测同名文件是否已经存在。(假设用于检测文件的库函数,在文件不存在时,会设置errno。那么fopen函数每次新建一个事先并不存在的文件时,即使没有任何程序发生错误,errno也仍然可能会被设置

因此,在调用库函数是,首先应该检测,作为错误指示的返回值,确定程序执行失败之后,再去检查errno,来搞清楚库函数系统调用时发生了什么。

/* 库函数调用 */
if(返回值判断)
{
    /* 错误结果 */
    if(errno == XXX)
    {
        /* 错误处理 */
    }
}
else
{
    /* 正确处理 */
}

是不是看到这里感觉代码优化的已经可以了,其实还不行!原因是如果在判断 if (errno == xxx) 判断之前如果有其他操作,比如打印,还有memset比较大的结构体等其他消耗时间的操作,这会影响到 if 判断。在前面提到的打印,memset,memcpy等操作正在进行时,可能有其他的进程,线程在系统调用库函数,修改了errno的值,所以上面的代码并不完美!

int level_err = 0;

/* 库函数调用 */

/*  在系统调用完成之后,第一件事情将errno保存到一个临时变量里面,排除其他系统调用的干扰  */

level_err = errno;  

if(返回值判断)
{
    /* 错误结果 */
    if(level_err == XXX)
    {
        /* 错误处理 */
    }
}
else
{
    /* 正确处理 */
}

### 回答1: "epoll read errno" 其实是指 Epoll 系统调用在进行读取操作时出现的错误编号。Epoll 是 Linux 系统中的一个高性能的 I/O 事件通知机制,用于监听文件描述符上的事件并进行相应的处理。当 Epoll 进行读取操作时,可能会发生各种错误,造成读取失败。 其中,errno 是一个全局变量,用于保存最后一次发生错误时的错误编号。 通常情况下,epoll read errno 可能的取值和对应的含义如下: 1. EAGAIN 或 EWOULDBLOCK:表示当前没有可读取的数据,即阻塞状态。 2. EBADF 或 EINVAL:表示被监听的文件描述符无效或者不是一个合法的 socket。 3. EINTR:表示 Epoll 被信号中断,需要重新调用。 4. EFAULT:表示需要读取数据的缓冲区指针无效。 5. ENOMEM:表示内存不足,无法为 Epoll 内部数据结构分配内存空间。 6. 其他错误:比如权限问题、文件已关闭等。 当程序中出现 "epoll read errno" 错误时,我们可以根据具体的错误编号来判断错误的原因,并采取相应的处理措施。可能的处理方法包括:重新尝试读取、更新监听的文件描述符、增加缓冲区大小、检查文件描述符的权限、检查内存使用等。具体的解决方法需要根据实际情况来定,以确保程序的正常运行。 ### 回答2: "epool read errno" 是一个错误信息,通常在使用 Linux 系统中的 epoll I/O 多路复用机制时出现。 在 epoll I/O 多路复用中,使用一个 epoll 对象来监视多个文件描述符(包括套接字和文件)的状态变化。当一个文件描述符准备好进行读操作时,epoll_wait 函数会返回,并且可以通过相应的文件描述符进行读取操作。然而,有时候在调用 epoll_wait 函数时,可能会收到 "epool read errno" 错误。 这个错误通常是由于以下几种情况引起的: 1. epoll 对象没有正确初始化或被关闭了。在使用 epoll_create 函数创建 epoll 对象时,如果返回值为 -1,就说明出错了。 2. epoll_wait 函数的返回值小于 0,表示出错。可以通过读取 errno 变量来获取具体的错误代码。 3. epoll_wait 函数的超时时间参数设置错误,导致超时立即返回,而不是等待任何事件的到来。 解决这个问题的方法包括: 1. 确保正确初始化并正确使用 epoll 对象。如果 epoll_create 函数返回 -1,可以检查 errno 变量来获取具体的错误信息,并相应地处理。 2. 针对 epoll_wait 函数的返回值小于 0 的情况,可以读取 errno 变量来获取具体的错误代码,并进行相应的处理措施。 3. 检查 epoll_wait 函数的超时时间参数是否正确设置。 总之,"epool read errno" 错误是在使用 epoll I/O 多路复用机制时可能会遇到的错误信息,我们需要根据具体的场景和错误代码来进行分析和处理。 ### 回答3: "epoll read errno" 是指使用 epoll 函数进行读操作时出现的错误。epoll 是 Linux 系统中一种高效的 I/O 多路复用机制,允许程序同时监视多个文件描述符,等待其中任何一个文件描述符变为可读或可写状态。而 "epoll read errno" 表示在使用 epoll 进行读操作时出现了错误。 通常,"epoll read errno" 错误的产生是由于以下几个常见原因: 1. 文件描述符错误:epoll 函数对于读操作要求输入参数是一个有效的文件描述符,如果文件描述符无效或已关闭,就会导致 "epoll read errno" 错误。 2. 读取缓冲区不足:当 epoll 函数读取数据时,需要提供一个足够大的缓冲区来存储读取的数据。如果缓冲区不够大,读取的数据可能会被截断,也可能导致 "epoll read errno" 错误。 3. 连接中断或错误状态:在使用 epoll 进行读操作时,如果连接中断或发生错误,epoll 函数会返回相应的错误码,比如 EPIPE、ECONNRESET 等,表示连接发生了错误,从而引发 "epoll read errno" 错误。 为了解决 "epoll read errno" 错误,可以采取以下措施: 1. 检查文件描述符的有效性,确保它是一个有效的、打开的文件描述符。 2. 确保读取缓冲区足够大,可以容纳要读取的数据。 3. 分析错误码,如 EPIPE、ECONNRESET 等,找到具体的错误原因并进行相应的处理。 总之,"epoll read errno" 错误是指在使用 epoll 函数进行读取操作时发生的错误。可以通过检查文件描述符的有效性、确保读取缓冲区足够大以及分析错误码等方式来解决该错误。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值