首页 > 解决方案 > 使用 C popen(): read() 有效,但 fread() 无效

问题描述

在 popen() 之后,fread() 总是返回 0。使用 read() 和 fileno(fp) 有效。这是怎么回事?

这是代码。

#include <errno.h>
#include <stdio.h>
#include <unistd.h>


int main(int argc, char *argv[]) {
    FILE *fp = popen("echo hello", "r");
    if (!fp) {
        perror("echo hello");
    } else {
        char buffer[128];
        for (;;) {
            int n;
            if (argc < 2) {
                n = fread(buffer, sizeof buffer, 1, fp);
            } else {
                n = read(fileno(fp), buffer, sizeof buffer);
            }
            printf("read %d bytes\n", n);
            if (n <= 0) break;
            fwrite(buffer, n, 1, stdout);
        }
        pclose(fp);
    }
}

如果没有命令行参数,代码使用 fread(),否则使用 read()。

输出:

$ ./test
read 0 bytes
$ ./test x
read 6 bytes
hello
read 0 bytes

标签: cpopenfread

解决方案


您告诉fread()要读取 1 个 100 字节长的项目。fread()返回已读取的完整项目数。由于流中只有 6 个字节,它在到达 EOF 之前无法读取任何项目,因此它返回0.

交换sizenitem参数的顺序,然后它将每个字节视为一个单独的项目,并返回它读取的字节数。

n = fread(buffer, 1, sizeof buffer, fp);

推荐阅读