C++递归,什么情况会栈溢出??

#include <iostream>//C++17

int numPP = 20;

//能跑,结束报错

int func2(int step)
{
    std::cout << numPP << std::endl;
    if (step == 10) return 1;
    return func2(step--);

}

//跑时会报错

int func2(int step)
{
   // std::cout << numPP << std::endl;
    if (step == 10) return 1;
    return func2(step--);

}

int main()

{

   func2(1000);

  return 0;

}

问题应该处在step--,后置--所得的结果为原值,意思就是你func2接收的一直是1000,所以第一个func2一直输出1000然后报错,第二个将输出注释直接报错。
这种程序应该用前置--,改为下面的代码试一下。

return func2(--step);

  return func2(step--); 修改为:   return func2(step - 1);