我有一个函数(遗留)读取文件的前几行以确定其类型,然后关闭并重新打开文件,以便它可以使用正确的解释器重新读取整个文件。要点是:
void readFile(const char *filename) {
ifstream is(filename);
Filetype ft = determineFileType(is);
is.close();
is.open(filename);
parseFile(is, ft);
}
我需要一个可以在已经打开的流上工作的类似函数。我创建了一个新函数,它采用 ostream &
而不是 char *filename
—— 基本上是这样的:
void readFile(istream &is) {
std::ios::streampos pos = is.tellg();
Filetype ft = determineFileType(is);
is.seekg(pos);
parseFile(is, ft);
}
当 istream
实际上是 stringstream
或 fstream
时,它似乎可以工作,但我想知道我是否只是走运。我还在 seekg
-ing std::cin
上做了一个小测试,结果成功了,这让我很惊讶。
那么我的问题:您允许在哪些类型的流上使用 seekg
?什么时候会失败?规范引用会很棒——我查看了 seekg
、pubseekpos
、seekpos
、seekoff
上的内容一点帮助都没有。
我想用新的(如下)重新实现原来的功能,但我不知道这样是否安全。
void readFile(const char *filename) {
ifstream is(filename);
readFile(is);
is.close();
}
最佳答案
唯一可以给出的真正答案是它在它起作用的地方起作用。在
对于 std::stringbuf
,它应该可以在任何地方工作。如果是
std::filebuf
,是否有效取决于系统;它会
如果 filebuf
在实际文件上打开,通常会工作,但会
通常会失败(如果系统没有报告错误,可能会默默地失败)
对于许多其他类型的输入:来自键盘或命名管道,例如
例子。
一个更健壮的解决方案是缓存初始输入,然后从缓存中重新读取它。
关于c++ - 您可以在哪些类型的输入流上调用 seekg?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7475043/