避免堆栈溢出c ++

时间:2019-11-13 05:47:07

标签: c++ recursion segmentation-fault c++17 stack-overflow

这是另一个系统生成的程序,因此它可能是重复性的,效率较低,或者应该是聪明的。发现是它具有很大的依赖性,并且属于深度递归函数。

因为向量可以达到1000个元素,并且它必须是连续的。崩溃时调用堆栈“ Calculation :: getItem(9)”>“ Calculation :: getItem(8)”>“ Calculation :: getItem(7)”>“ Calculation :: getItem(6)” ...崩溃之前返回正确的结果100。

新问题是:在不增加堆栈大小或不更改递归函数设计的情况下解决堆栈溢出的任何方法。

Calculation.cpp

std::optional<std::any> Calculation::getItem(int rowNo)
{
    if(calculatedRow[rowNo].has_value())
    {
      return calculatedRow[rowNo];
    }
    switch(rowNo)
    {
        case 0 : return calculatedRow[rowNo] = 0;
        case 1 : return calculatedRow[rowNo] = 100;
        case 2 : return calculatedRow[rowNo] = getItem(1)
        case 3 : return calculatedRow[rowNo] = getItem(2)
        case 4 : return calculatedRow[rowNo] = getItem(3)
        case 5 : return calculatedRow[rowNo] = getItem(4);
        case 6 : return calculatedRow[rowNo] = getItem(5)
        case 7 : return calculatedRow[rowNo] = getItem(6);
        case 8 : return calculatedRow[rowNo] = getItem(7);
        case 9 : return calculatedRow[rowNo] = getItem(8);
...
    }
    return 0;
}

Calculation.h

namespace Calculation
{
    //private namespace
    namespace
    {
       std::vector<std::optional<std::any>> calculatedRow(1000);
    }

    std::optional<std::any> getItem(int rowNo);
};

1 个答案:

答案 0 :(得分:2)

我对您的代码做了一些修改,然后运行它。当我用非常大的数字1024 * 128 - 1运行它时,出现错误。因此,我认为您的错误与调用堆栈限制有关。我的推论是由于您正在使用递归,您超出了调用堆栈限制和程序崩溃。我想在下面分享useful question和我的代码。

Calculation.h

#include <optional>
#include <any>
#include <vector>

namespace Calculation {
    //private namespace
    namespace {
        std::vector<std::optional<std::any>> calculatedRow(1024 * 128);
    }

    std::optional<std::any> getItem(int rowNo);
};

Calculation.cpp

#include <optional>
#include <any>
#include <iostream>
#include "Calculation.h"


std::optional<std::any> Calculation::getItem(int rowNo) {
    std::cout << rowNo << std::endl;
    if (calculatedRow[rowNo].has_value()) {
        return calculatedRow[rowNo];
    }
    switch (rowNo) {
        case 0 :
            return calculatedRow[rowNo] = 0;
        case 1 :
            return calculatedRow[rowNo] = 100;
    }
    return calculatedRow[rowNo] = getItem(rowNo - 1);
}

main.cpp

#include "Calculation.cpp"

int main() {
//    auto retVal = Calculation::getItem(1);
    auto retVal = Calculation::getItem(1024 * 128 - 1);
    if (retVal.has_value()) {
        std::printf("%d\n", std::any_cast<int>(retVal.value()));
    }
    return 0;
}

当我通过CLion运行它时,获得的日志是:

...
43776
43775
43774
43773
43772
43771
43770
43769

Process finished with exit code 11