在这段代码中,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);
答案 0 :(得分:0)
_popen
功能会创建管道。管道不是普通文件,它是一个单向字节流,数据从管道的一端流向另一端(就像现实生活中的管道一样)。
如果您被允许通过管道寻找,那么您只能寻求前进。您通过搜索跳过的任何数据都将消失。因此,即使它被允许向前寻找,因为在管道中没有反方向,向后搜索是没有意义的。
使用ftell
获取当前位置毫无意义,因为在&#34; current&#34;之前确实没有任何内容。在流中的位置,所以&#34;当前&#34;位置永远是开始。
如果要动态读取管道的输出,则必须使用动态分配和重新分配。通常应由std::vector
或std::string
处理C ++中的哪一个。