溢出这个词,并不少见,溢出带来的问题也会十分严重,那么数组溢出的原理是什么呢?
要理解数组溢出,我们首先要知道另外一个东西,其名曰:栈;
栈的介绍很简单如下图所示:
值得一提的是栈的栈底地址大,栈顶的地址小,知道了这个东西,对于理解溢出就简单多了。
当我们定义一个数组时,数组就是按序放入栈中的,如下图所示:
这就是将一个数组放入一个栈中 ,栈顶放地址小的,栈底放地址大的,以此类推
此时上述代码运行结果就是将i从0输出到9;
如果将代码改一下
#include <stdio.h>
int main()
{
int i;
int arr[10];
for(i=0;i<=10;i++)
{
arr[i]=0;
printf("%d\n",i);
}
}
此时是编译器就会报错,原因就是数组越界了,很明显,数组只有0~9十个下标,而for循环里面i代表的下标是从0~10有十一个,所以此时就会发生越界,编译器也就会报错,所以,为了避免越界,每次循环判断数组的时候一定要弄清数组的下标,在做循环。