我有一个 C++ 类 Archive
和一个成员函数 extractData()
。此函数调用在单独的 C 库中实现的 realExtractData()
。
我想向 extractData()
函数传递一对 FILE *
实例,通常是 stdout
和 stderr
,但我也想提供自定义文件指针的选项:
class Archive {
public:
...
int extractData(string id, FILE *customOut, FILE *customErr);
...
};
int
Archive::extractData(string id, FILE *customOut, FILE *customErr)
{
if (realExtractData(id.c_str(), customOut) != EXIT_SUCCESS) {
fprintf(stderr, "something went wrong...\n");
return EXIT_FAILURE;
}
return EXIT_SUCCESS;
}
如果我按列出的方式调用上面的代码,则在将数据输出到标准输出时没有延迟。所有提取的数据几乎立即发送到标准输出(stdout
):
FILE *outFp = stdout;
FILE *errFp = stderr;
Archive *archive = new Archive(inFilename);
if (archive->extractData(id, outFp, errFp) != EXIT_SUCCESS) {
fprintf(errFp, "[error] - could not extract %s\n", archive->getInFnCStr());
return EXIT_FAILURE;
}
如果我更改 extractData()
以便它的 fprintf()
调用使用 customErr
:
int
Archive::extractData(string id, FILE *customOut, FILE *customErr)
{
if (realExtractData(id.c_str(), customOut) != EXIT_SUCCESS) {
fprintf(customErr, "something went wrong...\n"); /* <-- changed this line */
return EXIT_FAILURE;
}
return EXIT_SUCCESS;
}
...然后当我运行二进制文件时,二进制文件似乎在处理输入和打印到标准输出时挂起。
如果我将 fprintf()
改回使用 stderr
而不是 customErr
,事情将再次正常工作,即,数据立即刷新到标准输出(我的 customOut
)。
这是缓冲问题吗?有办法解决这个问题吗?
最佳答案
“stderr 而不是 customErr”
标准错误是未缓冲的,这意味着它几乎会立即打印出来。除非您使用低级操作系统调用,否则其他输出流会被缓冲,这意味着它们将花费更长的时间来打印,除非您使用类似 endl、::flush 或其他任何东西进行缓冲区刷新。
如果您想进行低级操作系统调用并且您使用的是 unix,请查看:
http://www.annrich.com/cs590/notes/cs590_lecture_2.pdf
我还没有读完整本书,但在浏览它时,它看起来好像与优秀的 Stevens Advanced Programming in Unix 书中有类似的信息,这本书肯定会讨论这个问题。
关于c++ - 添加带有自定义标准错误的 fprintf() 语句后标准输出挂起,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8927117/