加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c – 为什么我的程序有无限循环?

发布时间:2020-12-16 03:16:48 所属栏目:百科 来源:网络整理
导读:int main(void){ int i; int array[5]; for (i = 0; i = 20; i++) array[i] = 0; return 0;} 为什么上面的代码陷入无限循环? 解决方法 以下是给定代码中发生的情况. #includestdio.h#includestring.hint main(void){ int i; int array[5]; for (i = 0; i =
int main(void)
{
    int i;
    int array[5];

    for (i = 0; i <= 20; i++)
    array[i] = 0;

    return 0;
}

为什么上面的代码陷入无限循环?

解决方法

以下是给定代码中发生的情况.
#include<stdio.h>
#include<string.h>
int main(void)
{
    int i;
    int array[5];

    for (i = 0; i <= 20; i++)
    {
        printf("%p %p n",&i,&array[i]);
        printf("the value of i is %d n",i);
        sleep(1);
        array[i] = 0;
        printf("i may be modified here lets see what i is %d n",i);
    }

    return 0;
}

在我的堆栈内存中,我获得了地址位置

我存储在位置0xbfd1048c地址

并且数组存储在位置0xbfd10478地址

当您在一个时间点递增每个循环的i值时,array [i]的地址等同于i的地址(它的只是指针取消引用)

所以你在数组[i]中存储的只不过是我的实例地址,所以你把我的实例值写成0,就像你提到的数组[i] = 0,这相当于i = 0,所以条件i < = 20总是成功. 现在的BIG问题为什么以这样的方式分配内存. 在运行时决定内核的资源可用性. 所以这就是为什么我们必须在阵列的极限中居住.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读