qq_54895398 2024-01-09 05:40 采纳率: 0%
浏览 7

爆栈发生时递归的**层数**为什么不是**固定**的?

源码:

#include <stdio.h>
void Lock ( unsigned long long n ) {
    printf ( "第%lld次调用\r", n );
    Lock ( n + 1 ); }
int main ( void ) {
    unsigned long long N = 0;
    Lock ( N );
    return 0; }

运行结果(前三次):

img

如图,连续执行三次上述代码后发现得到3221225725返回值时程序执行Lock(n)的次数不一样,执行时间和消耗的cpu和内存资源也不一样
继续执行:

序号最后打印的N值执行用时/scpu time /msmem /KB
#014314425.43390.65168
#024313924.24421.95164
#034315724.95687.55164
#044314623.11187.55164
#054314122.9205168
#064314125.0311565160
#074315624.58671.95164
#084315323.08453.15164
#094316522.6205164
#104315324.56359.45164

也就是说程序的运行是不确定的?还是说这是未定义行为?
IDE: RedPanda-C++
编译器: MinGW-w64 GCC 11.4.0 64-bit Debug
系统: Windows 11 家庭版

  • 写回答

3条回答 默认 最新

  • threenewbee 2024-01-09 09:37
    关注

    用 vc++ 的 release 方式编译看看
    其它编译器调试器都有可能占用堆栈造成干扰

    评论

报告相同问题?

问题事件

  • 创建了问题 1月9日