繁体   English   中英

递归Java方法给出堆栈溢出错误

[英]Recursive Java method giving stack overflow error

我试图弄清楚为什么我得到以下递归方法的堆栈溢出错误。 该方法用于检查Bed类型的ArrayList是否可用。 它需要连续/一起找到可用的numOfBeds ,然后返回第一个的位置,这样我就可以从列表中的那个位置开始连续预订指定的数量。 给出的参数: pos =起始位置, numOfBeds =要查找的金额, bedList =一个ArrayList 递归调用将在找到不可用的床之后有一个起始点。 提前致谢!

    public int multiEmptyBeds(int pos, int numOfBeds, ArrayList<Bed> bedList)
    {
    int check = pos;
    int count = 0;

    if(pos >= bedList.size())
        return -1;
    while(count != numOfBeds)
        {
        if(bedList.get(check).ifAvailable())
            check++;
        else
            break;
        count++;
        }
    if(count == numOfBeds)
        return pos;
    return multiEmptyBeds(check++, numOfBeds, bedList);
    }

编辑:解决了! 见下面的解决方案/优化...

您在recursive-call语句中的问题:

return multiEmptyBeds(check++, numOfBeds, bedList);

++运算符的后缀形式的语义就是这样,只有在被调用函数返回后才会改变变量check值。

你必须使用前缀形式增量运算符++

return multiEmptyBeds(++check, numOfBeds, bedList);

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM