学Java的时候边学边写代码,遇到一个非常奇怪的问题。
众所周知,一般高级语言的一般输出语句实际上都并不能保证将内容实时显示到标准输出(如C/++的printf()
,Python的print()
,等等等等),而是写入一个叫做缓冲区(一般称为buffer)的一段内存空间。输入有输入buffer,输出有输出buffer,大多数的文件操作符都会定义一个自己的buffer。1
buffer的好处不用多说,由于buffer
在内存上,可以随机存取,速度比硬盘之类的存储介质快几个数量级;但是buffer也有弱点,那就是刷写策略的问题。
一般在调用诸如printf()
时,由于C/++的刷写策略有一条是遇到换行符\n
就进行一次刷写。Python也有类似的策略,你可以通过指定flush=True
来让print()
函数立即刷写buffer到文件。
重头戏来了:学Java的输出语句System.out.printf()
的时候,我从代码补全看到System.out.flush()
,本以为这就是Java的刷写函数,结果
完 全 不 是 这 么 回 事 ! ! !
看下这段代码
import java.io.*;
import static java.lang.Math.round;
public class aClass {
public static void main(String[] args) {
int mod=26;
for (int i = 0; i < 100; i++) {
System