黑马程序员技术交流社区
标题:
深藏不露的递归
[打印本页]
作者:
li3N
时间:
2015-11-11 20:44
标题:
深藏不露的递归
阅读以下程序,说法正确的是()
public class Demo {
Demo d = new Demo();
public static void main(String[] args) {
Demo d2 = new Demo();
}
}
复制代码
A、程序正常运行,但没有结果
B、编译报错
C、程序运行后出现内存错误
D、程序运行会死循环
答案是C,编译没问题(因为没有语法错误),运行后一段时间,报栈内存溢出错误(StackOverflowError)。
API的解释是当应用程序递归太深而发生堆栈溢出时,抛出该错误。
运行过程:主函数先执行,创建局部变量d2,执行new对象动作
而d是成员变量,在主函数new对象的时候,它被赋值为一个new对象
所以程序在第二句话上不断的new对象,也算是递归。
此时栈内存不是被不弹栈的方法堆满的,而是被茫茫多的Demo类型变量d堆满的。很难想象与之对应的堆内存里放了多少Demo对象。
作者:
candlelight
时间:
2015-11-11 23:30
汗,这递归,报了一端执行异常
欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/)
黑马程序员IT技术论坛 X3.2