欢迎来到代码驿站!

JAVA代码

当前位置:首页 > 软件编程 > JAVA代码

java基础(System.err和System.out)详解

时间:2020-12-07 16:37:57|栏目:JAVA代码|点击:

今天有位同事在使用System.err和System.out遇上了一些小问题.

看了些资料总结下:

1.JDK文档对两者的解释:

out:“标准”输出流。此流已打开并准备接受输出数据。通常,此流对应于显示器输出或者由主机环境或用户指定的另一个输出目标。

err:“标准”错误输出流。此流已打开并准备接受输出数据。通常,此流对应于显示器输出或者由主机环境或用户指定的另一个输出目标。按照惯例,此输出流用于显示错误消息,或者显示那些即使用户输出流(变量 out 的值)已经重定向到通常不被连续监视的某一文件或其他目标,也应该立刻引起用户注意的其他信息。

2.out和err的一个区别是,out往往是带缓存的,而err没有缓存(默认设置,可以改)。所以如果你用标准出错打印出来的东西可以马上显示在屏幕,而标准输出打印出来的东西可能要再积累几个字符才能一起打印出来。如果你在应用中混用标准输出和标准出错就可能看到这个问题。

测试代码:

public class Test2 {
  static{
    System.out.println("1");
  }
  public static void main(String[] args) {
    System.err.println("2");
    new Test2();
  }
  public Test2() {
    System.out.println("3");
  }
  
}

测试结果: 1,3的位置相对不变,2的位置随机出现.尽量避免混用!

3.如果使用了log4j的日志记录,System.err会被记入日志,System.out不会

ps:打印System.err在eclipse是红色的。System.out是蓝色的。

上一篇:Java实现快速排序算法(Quicktsort)

栏    目:JAVA代码

下一篇:JDK14的新特性:instanceof模式匹配的使用

本文标题:java基础(System.err和System.out)详解

本文地址:http://www.codeinn.net/misctech/30170.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有