微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

从非阻塞命名管道读取在 Ubuntu 中给出 EFAULT (14)

如何解决从非阻塞命名管道读取在 Ubuntu 中给出 EFAULT (14)

下面的代码返回 EFAULT (errno == 14)。如果您能帮助我找出原因,我将不胜感激。

我也尝试使用 select() 实现代码,但仍然得到相同的错误代码

我在 Python 上运行了非常相似的代码,没有任何问题。

#include <stdio.h> 
#include <string.h> 
#include <fcntl.h> 
#include <sys/stat.h> 
#include <unistd.h> 
#include <errno.h> 



int read_fail1(int fd)
{
    int n;
    char buf[500];

    for (;;)
    {
        buf[strlen(buf)-1] = 0;
        n = read(fd,buf,strlen(buf)-1);
        
        if (n == -1)
        {
            if (errno == EFAULT)
            {
                fprintf(stderr,"EFAULT");
                return 42;
            }
        }
        else if (n > 0)
        {
            fprintf(stderr,"%s",buf);
        }

    }
}



int main(int argc,const char *argv[])
{
    const char *myfifo = "pipeMUD";
  
    mkfifo(myfifo,0666); 
  
    int fd = open(myfifo,O_RDWR | O_NONBLOCK);

    if (fd <= 0)
        return 42;

    read_fail1(fd);

    return 0;
}

发布答案编辑:

正如在下面链接的帖子中提到的,如果将无效地址传递给内核,它会抛出 EFAULT。我猜在Linux上,根据上面的代码,给read()传递一个长度为0的count参数也会导致EFAULT被返回。

unix socket error 14: EFAULT (bad address)

解决方法

这一行:

buf[strlen(buf)-1] = 0;

buf 如果是局部变量,因此不在 C 中初始化。 strlen 查找 '\0'(空字符)值,因此会对未初始化的数组产生不可预测的结果。

但是,只要您像这样静态声明 buf,就可以改用 sizeof。 虽然最好使用宏来代替:

#define READ_BUFFER_SIZE 500

char buf[READ_BUFFER_SIZE];
n = read(fd,buf,READ_BUFFER_SIZE - 1);

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?