使用Cpopen():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 bytesn", 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

回答

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

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

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


以上是使用Cpopen():read()有效,但fread()无效的全部内容。
THE END
分享
二维码
< <上一篇
下一篇>>