当printf可以自己打印时,为什么在printf之后使用fflush?

问题描述

我是C语言的新手,很抱歉,如果我的问题太基础了。我经常看到如下代码:

printf("%d",counter);
fflush(stdout);

我的猜测是,如果缓冲区未满,它将不会输出输出,因此您需要刷新stdout。但是我尝试不使用fflush,仅使用printf,但仍然没有打印在屏幕上,那么使用flush有什么意义呢?

解决方法

fflush之后使用printf的主要原因是计时。

printf将在某个时间点显示信息。基本上所有到printf的打印都会被缓冲。 fflush确保清空了缓冲区,这意味着打印发生在名为fflush的代码行上。

在容易崩溃的程序中,fflush是一个非常有用的工具。通常,程序用户希望收到的消息是崩溃之前最后打印的消息。如果程序没有fflush,则该用户可能不会获得最后的print语句,并且该语句在显示之前会丢失在缓冲区中。

这通常会导致开发人员在崩溃后分析日志文件时,在程序源代码中的错误位置查找错误。实际过程是“嗯,它不可能在这里完成,因为我们会看到printf,而实际上是程序通过了“是否会看到” printf语句,但是死于缓冲区中的该消息。如果在打印语句后立即刷新语句,则不会发生(尽管程序运行较慢,因为刷新需要时间)。

相关问答

错误1:Request method ‘DELETE‘ not supported 错误还原:...
错误1:启动docker镜像时报错:Error response from daemon:...
错误1:private field ‘xxx‘ is never assigned 按Alt...
报错如下,通过源不能下载,最后警告pip需升级版本 Requirem...