现象
代码:
System.out.println("username: ");
System.err.println("password: ");
System.out.println("username: ");
System.err.println("password: ");
System.out.println("username: ");
System.err.println("password: ");
控制台输出:
password:
password:
username:
username:
username:
password:
解释
大多数操作系统都有三个标准文件描述符:标准输入,标准输出,标准出错。
对应Java中的System.in,System.out,System.err。
在语言层面的实现三个文件描述符都是可以重定向的(只要你想),
但是一般而言,如果你在unix shell或windows command line中使用管道或重定向,则只是针对标准输入和输出。
另外,标准输出和标准出错的一个区别是:标准输出往往是带缓存的,而标准出错没有缓存(默认设置,可以改)。
所以如果你用标准出错打印出来的东西可以马上显示在屏幕,而标准输出打印出来的东西可能要再积累几个字符才能一起打印出来。
如果你在应用中混用标准输出和标准出错就可能看到这个问题。
总的来说,System.out用于正常的输出,也就是程序真正想输出的内容。而System.err用于出错信息的输出,也就是你本来不期待看到的东西。
因此,System.out可能会被缓冲,而System.err不会,由于System.err不需要缓冲即可输出,直接造成了我们视觉上看到的其位置的不确定性