public
class
TestCodeSeg
{
static
{
System.out.println(
"1"
);
}
{
System.out.println(
"2"
);
}
public
TestCodeSeg()
{
System.err.println(
"3"
);
}
public
static
void
main(String[]args)
{
new
TestCodeSeg();
}
}
结果 可能是
3
1
2
或者
13
2
或者
1
3
2
或者
1
3
2
或者
1
23
或者
1
2
3
System.out.println可能会被缓冲,而System.err.println不会
System.out
“标准”输出流。此流已打开并准备接受输出数据。通常,此流对应于显示器输出或者由主机环境或用户指定的另一个输出目标。
System.err.println()是要缓冲的,所以优先级会高点,而System.out.println()是不需要缓冲的,所以优先级会低点.
很多开发者都不了解为什么出错和调试时使用System.err。
当输出一个流时,JVM和操作系统共同决定何时输出这个流。也就是说,尽管开发者键入了:
System.out.print_
("Test Output:");
JVM和操作系统的组合体并不会立即输出这个流。相反,它将保持等待状态直到将要输出的东西达到一定的量。
假设输入以下指令:
System.out.println("Debugging Info.");
JVM可能同意输出;然而,操作系统可能决定暂不输出。
由于这个原因,在调试程序时想要发现出错的位置就有可能成为问题。考虑以下的程序:
for(int i=0; i<56; i++) {
System.out.println(i);
... // containing an error
}
错误可能出现在i等于54时,但是可能JVM在i等于49时就结束输出了。50到54仍然存在于缓存中,结果也就丢失了。
使用System.err来报告错误、调试程序就可以避免这种情况出现,它将使每一次操作的结果都输出出来。例如以下程序:
for(int i=0; i<56; i++) {
System.err.println(i);
... // containing an error
}
在每一次i等于54时都将显示错误信息。