java try-catch-finally递归问题
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了java try-catch-finally递归问题,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1347字,纯文字阅读大概需要2分钟。
内容图文
![java try-catch-finally递归问题](/upload/InfoBanner/zyjiaocheng/808/7c45163115cf412ebb36fa57b7b6c2cc.jpg)
public class Foo {
public static void main(String[] args) {
foo();
}
public static void foo() {
try {
System.out.println("try");
foo();
} catch (Throwable e) {
System.out.println("catch");
foo();
} finally {
System.out.println("finally");
foo();
}
}
}
谁能解释一下这段代码的输出?
1.在eclipse(无尽)客户端模式下输出:
try try .... ... ... tryfinallyfinally tryfinallyfinally try try try tryfinallyfinally tryfinallyfinally try tryfinallyfinally tryfinallyfinally try .... ....
2.output on linux(crash)服务器模式:
try try ... ... try try try try try try MISSING EXCEPTION HANDLER for pc 0x00002aaaab1c53f0 and handler bci -1 Exception: Compiled exception table : ExceptionHandlerTable (size = 3304 bytes) catch_pco = 700 (1 entries) bci -1 at scope depth 0 -> pco 11039 catch_pco = 1736 (1 entries) bci -1 at scope depth 0 -> pco 11473 catch_pco = 1756 (1 entries) bci -1 at scope depth 0 -> pco 11433 catch_pco = 1776 (1 entries)
解决方法:
我想我从“Java Puzzlers”一书中记得这一点. try块执行无限递归,很快导致抛出StackOverflowError. try和catch块恢复递归,但具有相应较小的剩余堆栈.但是,当每个递归调用返回时,剩余的堆栈会再次变大…
最终结果是一个调用图,它根据堆栈的大小形成一个深度为树的树;使用主流JVM的默认堆栈大小,树变得如此之大,以至于您必须等待数十亿年才能完全遍历并终止程序.
编辑:这就是您在客户端模式中看到的内容:遍历调用图.您在Linux服务器模式下看到的是JVM错误或硬件缺陷(错误的RAM可能会产生这种影响).
内容总结
以上是互联网集市为您收集整理的java try-catch-finally递归问题全部内容,希望文章能够帮你解决java try-catch-finally递归问题所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。