再来一例程序,手动触发StackOverflowError异常:
如下:
public class JavaVMStackSOF {
private int stackLength = 1;
public void stackLeak() {
stackLength++;
stackLeak();
}
public static void main(String[] args) throws Throwable {
JavaVMStackSOF oom = new JavaVMStackSOF();
try {
oom.stackLeak();
} catch (Throwable e) {
System.out.println("stack length:" + oom.stackLength);
throw e;
}
}
}
抛出异常:
stack length:10050
Exception in thread "main" java.lang.StackOverflowError
at com.jobmonitor.test.JavaVMStackSOF.stackLeak(JavaVMStackSOF.java:13)
at com.jobmonitor.test.JavaVMStackSOF.stackLeak(JavaVMStackSOF.java:13)
at com.jobmonitor.test.JavaVMStackSOF.stackLeak(JavaVMStackSOF.java:13)
at com.jobmonitor.test.JavaVMStackSOF.stackLeak(JavaVMStackSOF.java:13)
at com.jobmonitor.test.JavaVMStackSOF.stackLeak(JavaVMStackSOF.java:13)
at com.jobmonitor.test.JavaVMStackSOF.stackLeak(JavaVMStackSOF.java:13)
而且从打印出的信息也可以看出,本程序测试所使用的java虚拟机的设置的栈大小是10050,超过这个就会抛出异常了~~
源程序引自《深入理解Java虚拟机》-周志明著
本文通过一个递归调用的例子展示了如何手动触发StackOverflowError异常,该异常发生在Java虚拟机栈内存耗尽时。
5604

被折叠的 条评论
为什么被折叠?



