当前位置: 代码迷 >> Eclipse >> 为何用Eclipse运行这段代码每次的结果总是不一样
  详细解决方案

为何用Eclipse运行这段代码每次的结果总是不一样

热度:90   发布时间:2016-04-23 12:47:03.0
为什么用Eclipse运行这段代码每次的结果总是不一样?
代码:
public class PrintErrorAndDebug {
public static void main(String[] args)
{
System.out.println("main()方法开始运行");
//输出错误信息
System.err.println("在运行期间手动输出一个错误信息");
System.err.println("该软件没有卖保险,请注意安全");
System.out.println("PrintErrorAndDebug。main()");
System.out.println("main()方法运行结束");
}
}

每次运行之后的语句顺序总是不同

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

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

------解决方案--------------------
System.out和System.err是两个不同的流,输出当然也没有可比性。
比如两辆车同时上两座桥,谁先下这个是不一定的
------解决方案--------------------
标准输出和标准出错不能混用,正常输出一般用标准输出
  相关解决方案