首先我们就来先看看这道题目是什么
试分析出下列代码的运行结果,并说明为什么会出现这种结果?
#include <stdio.h>
int main()
{
int i = 0;
int a[3];
for (i = 0; i <= 5; i++)
{
a[i] = 0;
printf("%d\n", i);
}
return 0;
}
真个代码看起来就有些问题,但是又不知道有什么问题???
那我们先看看他的运行结果是什么吧!
0 1 2 3 4 开始死循环了,这是为啥呢???感觉像是数组越界呀,问啥不报错呢?
如果要深究,那就有的说头了,先画张图感受一下吧。
大家都知道,我们的局部变量都是存储在栈区空间里的,而栈区中内存使用是先使用高地址
空间,在使用低地址空间,因为int i 是在int a数组之前创建的,所以 i 变量是高地址,
数组a是在低地址。而数组存储是随着数组下标的增加,地址从高到低,所以数组从上到下依
次是 a[2] a[1] a[0],
接下来就是关键了,进入for 循环,i变量依次增加到3,a[2] a[1] a[0],的数据也都清零,屏幕
也打印出0 1 2 到 下一次循环,i++后,a[4] = 0,这时其实已经非法访问数组以外的内容了,但是任然可以置零,等到 i 变量变成5时,
变量 i 也变成0了,导致 i 又从0开始循环了,这就是问题所在,
其实你打开a[5]发现a[5] = 3,其实a[5] 就是i a数组因为在高地址上,所以恰好数组非法访问
到i 了,导致i变量被置零,这就是问题的原因。
所以这题考得就是你对栈区变量存储的位置清不清楚(从高地址到低地址存放),另外数组在
栈区存放是岁下表的增加,存放到高地址,其实在不同的编译环境下,变量的存储位置会有
不同,但是只要越界到一定位置都会出现这种情况(访问到高地址的数据)。
所以我们又尽量避免数组的越界访问呀。。。。