java 积累递归深度_java递归的深度

递归的深度

在使用递归的时候经常会抛出StackOverflowError,顾名思义就是栈满了,而我们这里所说的栈在java中通常就是虚拟机栈(vm stack),在每个方法执行的同时都会创建一个栈帧,用于存储局部变量表、操作数栈,动态链接,方法出口等信息,每一个方法从调用直到执行结束的过程就对应着一个栈帧在虚拟机栈中入栈到出栈的过程。

a16ff2832c8671edabd8126049204b32.png

虚拟机栈的深度是固定的,所以虚拟机栈中所装的栈帧的多少取决于栈帧的大小,而栈帧的大小就取决于

局部变量表、操作数栈,动态链接,方法出口四个的大小,而我们最熟悉的应该是局部变量表,用于存储方法中定义的局部变量的,因此局部变量越多栈所能装下的栈帧也就越少。写个程序验证一下:

//局部变量表大的方法

public void large(int a) {

try {

//使用随机数确保每一个字符串都不相同,效果更明显

String b = String.valueOf(100* Math.random());

String c = String.valueOf(100* Math.random());

String d = String.valueOf(100* Math.random());

String e = String.valueOf(100* Math.random());

String f = String.valueOf(100* Math.random());

String g = String.valueOf(100* Math.random());

a++;

large(a);

} catch (StackOverflowError error) {

System.out.println("large方法 " + a + " 层");

}

}

//局部变量表小的方法

public void small(int a) {

try {

a++;

small(a);

} catch (StackOverflowError error) {

System.out.println("small方法" + a + " 层");

}

}

分别运行large方法和small方法,运行结果如下:

4b1dab8557af76365161850b9a877125.png

9c79fd014ae08ada6dd41771060b2a07.png

从结果来看,差距还是挺明显的。

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值