测试输出System.err与System.out

来源: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...

相关文章
相关标签/搜索