在 Java 中,flush()
方法用于流中。但我不明白使用这种方法的全部目的是什么?
fin.flush();
告诉我一些建议。
从方法的文档中flush
:
刷新输出流并强制写出任何缓冲的输出字节。flush 的一般约定是调用它表示,如果先前写入的任何字节已被输出流的实现缓冲,则应立即将这些字节写入其预期目的地。
缓冲主要是为了提高 I/O 性能。有关这方面的更多信息,请参阅这篇文章:Tuning Java I/O Performance。
当您将数据写入流时,它不会立即写入,而是被缓冲。因此flush()
,当您需要确保缓冲区中的所有数据都已写入时使用。
我们需要确保在关闭流之前完成所有写入,这就是为什么flush()
在文件/缓冲写入器中调用close()
.
但是,如果您要求在关闭流之前随时保存所有写入,请使用flush()
.
当我们发出任何命令时,该命令的流存储在我们计算机中称为缓冲区(临时内存位置)的内存位置中。当所有临时内存位置已满时,我们使用 flush(),它刷新所有数据流并完全执行它们,并为缓冲区临时位置中的新流提供新空间。-希望你能理解
如果缓冲区已满,则缓冲在其上的所有字符串都将保存到磁盘上。缓冲区用于避免大交易!和开销。
在放置在 java 库中的 BufferedWriter 类中,有一行如下:
private static int defaultCharBufferSize = 8192;
如果您确实想在缓冲区满之前发送数据,那么您确实可以控制。只是冲洗它。对 writer.flush() 的调用说,“现在发送缓冲区中的任何内容!
参考书:https ://www.amazon.com/Head-First-Java-Kathy-Sierra/dp/0596009208
页数:453
流通常由定期清空其内容的线程访问,例如,将其显示在屏幕上,将其发送到套接字或将其写入文件。这样做是出于性能原因。刷新输出流意味着您要停止,等待流的内容完全传输到其目的地,然后在流为空并发送内容的情况下恢复执行。
对于性能问题,首先将数据写入 Buffer。当缓冲区已满时,数据将写入输出(文件、控制台等)。当缓冲区部分填充并且您想将其发送到输出(文件,控制台)时,您需要手动调用 flush() 方法以便将部分填充的缓冲区写入输出(文件,控制台)。
除了这里的其他好的答案之外,这个解释对我来说很清楚:
缓冲区是内存中用于存储数据流(字符)的一部分。这些字符有时只会在缓冲区已满或遇到一定数量的字符时才会发送到输出设备(例如监视器)。如果您只有几个字符要发送到输出设备,这可能会导致您的系统滞后。flush() 方法将立即将缓冲区的内容刷新到输出流。