System.out.println()和System.err.println()

自己写了main方法测试的时候,多执行几次的时候就会出现下面的结果.......看到真相的我竟然惊呆了...

最近在项目中使用的时候,打印到控制台的时候,想区分一些重要信息,就考虑到了.serr(idea中System.err.println()的快捷键).感觉可以直观一点展示在控制台数据..

  • err是运行期异常和错误反馈的输出流的方向
  • System.err.println只能在屏幕上实现打印,即使你重定向了也一样
  • 用err打印出的 字符串,再eclipse的console会显示成红色
  • 标准输出往往是带缓存的,而标准出错没有缓存(默认设置,可以改)

对应Java中的System.in(标准输入),System.out(标准输出),System.err(标准出错)。

在语言层面的实现三个文件描述符都是可以重定向的(只要你想),

但是一般而言,如果你在unix shell或windows command line中使用管道或重定向,则只是针对标准输入和输出。

另外,标准输出和标准出错的一个区别是:标准输出往往是带缓存的,而标准出错没有缓存(默认设置,可以改)。

所以如果你用标准出错打印出来的东西可以马上显示在屏幕,而标准输出打印出来的东西可能要再积累几个字符才能一起打印出来。

如果你在应用中混用标准输出和标准出错就可能看到这个问题。

总的来说,System.out用于正常的输出,也就是程序真正想输出的内容。而System.err用于出错信息的输出,也就是你本来不期待看到的东西。

因此,System.err打出来的信息常常会跑到System.out信息的前面去。这只是在第一次打印的时候,之后的时候,会抢占资源,可能是out的缓存先执行.也可能是即时的err先执行...

所以,总结就是....统一标准,

要么全out比较,要么全err比较....因为out和err没有比较的价值.

猜你喜欢

转载自blog.csdn.net/younglee16/article/details/81222492