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问题为什么以这样的方式分配内存. 在运行时决定内核的资源可用性. 所以这就是为什么我们必须在阵列的极限中居住.