#include<stdio.h>
int main()
{
int i = 0;
int arr[] = { 1,2,3,4,5,6,7,8,9,10 };
for (i = 0; i <= 12; i++)
{
arr[i] = 0;
printf("hello world\n");
}
}
因为 i 和 arr[ ]是局部变量,存放在栈区,栈区先使用高地址,在使用低地址,所以i的地址大,arr[]地址小,又因为随着下标的增加,地址是由低到高变化的,即i和arr[]在内存中的存储如图
| i=0 |
| arr[9]=10 |
| arr[8]=9 |
| arr[7]=8 |
| arr[6]=7 |
| arr5]=6 |
| arr4]=5 |
| arr3]=4 |
| arr[2]=3 |
| arr[1]=2 |
| arr[0]=1 |
随着i的增加,当i = 12时,arr[12] = 0,此时,arr[12]与i的地址相同,i也被赋值为0,循环又重新开始,所以出现了死循环。
该代码示例展示了C语言中栈区内存分配的一个例子,其中数组`arr`和变量`i`是局部变量。由于栈区的地址从高到低分配,当`i`增长到12并覆盖了`arr[12]`的位置,将`arr[12]`置零的同时也重置了`i`的值,导致无限循环。这种现象揭示了内存管理的重要性以及对栈内存理解的必要性。
314

被折叠的 条评论
为什么被折叠?



