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问题为什么以这样的方式分配内存. 在运行时决定内核的资源可用性. 所以这就是为什么我们必须在阵列的极限中居住. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |