Java递归,递归改循环

本文探讨了Java中递归的使用,指出由于可能导致栈溢出,递归并不总是推荐的解决方案。虽然递归在某些情况下使代码更简洁,但需要注意结束条件。理论上所有递归都能转换为循环,文中举例说明了如何将嵌套递归转换为循环,并指出在避免栈溢出风险的情况下,可以优先考虑使用递归。
摘要由CSDN通过智能技术生成

Java递归,递归改循环

为什么大家都说不建议用递归?

递归容易造成栈溢出,在jdk1.5前虚拟机给每个栈桢的运行空间128kb,在1.5以后为1m的运行空间.递归是指先进后出,也就是说第一进栈的对象会最后一个出站,然后栈桢的空间只有1m,生产环境的数据需要递归的深度,一般情况下我们无法通过测试来进行模拟。所以对于递归的深度不可把控的情况下,是有栈溢出的风险。

一个简单的例子测试递归的深度

在这里插入图片描述
在这里插入图片描述

递归的使用注意点

1.注意递归的结束条件

递归的优势

代码简单清晰,一看就懂,如果在不会照成栈溢出还是建议使用递归的。

所有的递归都可以改循环吗?理论上是可以的。以下一个嵌套递归,改循环的例子

嵌套递归:工作要求需要将一个集合中有subList的对象的code记录一下,无subList对象的code记录在一起

  //递归查到所有的drugtypes
  //嵌套递归,将drugTypes中有子集的code放在一个list中,没有子集的code放在一个list中。
  private void setHasChild( List<BaseDrugType> drugTypes,List<String> hasChildCodeList ,List<String> hasNotChildCodeList){
   

    for (BaseDrugType drugType:drugTypes){
   
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值