_popen(dir,rt)fseek(dir和ftell()返回0

时间:2018-04-03 19:23:29

标签: c++ directory popen fseek ftell

在这段代码中,ftell(dir)返回0.但是当我用fread_s()读取时,所有预期的文本都出现了。知道为什么ftell()在这种情况下会返回0吗?

FILE* dir = _popen("dir", "rt");
    if (dir == NULL) {
        send(socket, "0", 10, 0);
        cerr << "\nerror opening dir" << endl;
        return;
    }
    int r = fseek(dir, 0, SEEK_END);
    if (r != 0) {
        send(socket, "0", 10, 0);
        cerr << "\nerror seeking end" << endl;
        return;
    }
    long dirLength = ftell(dir);
    fseek(dir, 0, SEEK_SET);
    cout << "dirLength " << dirLength << endl;
    char dirListLength[10];
    memset(dirListLength, 0, 10);
    sprintf_s(dirListLength, 10, "%u", dirLength);
    cout << "dirListLength " << dirListLength << endl;
    send(socket, dirListLength, 10, 0);

    long sentDir = 0;
    char buffer[BUFFER_SIZE];
    memset(buffer, 0, BUFFER_SIZE);
    while (fread_s(buffer, BUFFER_SIZE, sizeof(char), BUFFER_SIZE, dir) > 0) {
        send(socket, buffer, BUFFER_SIZE, 0);
        cout << buffer << endl;
        cout << 1 << endl;
        memset(buffer, 0, BUFFER_SIZE);
    }
    _pclose(dir);

1 个答案:

答案 0 :(得分:0)

_popen功能会创建管道。管道不是普通文件,它是一个单向字节流,数据从管道的一端流向另一端(就像现实生活中的管道一样)。

如果您被允许通过管道寻找,那么您只能寻求前进。您通过搜索跳过的任何数据都将消失。因此,即使它被允许向前寻找,因为在管道中没有反方向,向后搜索是没有意义的。

使用ftell获取当前位置毫无意义,因为在&#34; current&#34;之前确实没有任何内容。在流中的位置,所以&#34;当前&#34;位置永远是开始。

如果要动态读取管道的输出,则必须使用动态分配和重新分配。通常应由std::vectorstd::string处理C ++中的哪一个。