来源:http://www.cnblogs.com/guozp/p/6099902.htmlhtml
一、System.out在JVM和操做系统都具备缓存功能,输出的东西不必定实时输出,可能积累几个字符才会一块输出缓存
二、System.err 不带缓存(默认,可修改),会实时输出,打印的东西能够立马显示在屏幕。
三、若是使用了log4j的日志记录,System.err会被记入日志,System.out不会。
四、JDK的解释是System.out是一般输出信息的方式,System.err是用在显示错误信息或者system.out被重定向之后,须要当即让用户注意到的信息的输出。测试
注意:单用其中一种都不会出问题,可是若是混用的话(System.err和System.out),就会输出顺序可能不是本身想要的。千万不要小看这个输出顺序问题,当你测试线程的输出顺序或者其余依赖顺序来判断执行过程的时候,这个时候就若是输出乱序的话,可能就会让你放弃某个方案。spa
若是测试依赖顺序时必定要注意!操作系统
附上简单的用例:线程
public class Test { public static void main(String[] args) { System.out.println("start..."); System.err.println("middle..."); System.out.println("end..."); } }
理想输出:日志
start...
middle...
end...code
屡次测试会出现如下输出:htm
middle...blog
start... end...