C:数组越界,数组进栈

        首先,展示一段最常见的数组越界。

        先定义int型的变量i,再定义整型数组,长度为10,然后for循环时,给i初始化,即i=0,判断i<=10若为真,则给数组中的所有值赋值为0,然后依次输出i的变化;否则,循环结束。

代码如下:

#include <stdio.h>
int main ()
{
	int i;
	int arr[10];

	for(i = 0;i <= 10;i ++)
	{
		arr[i] = 0;
		printf("%d\n",i);
	}
}

结果如下图:

                                   

        编译器(Visual Studio 2012)报错!

        原因:数组长度为10,但是数组编号是从0开始到9,共10个位置,编译器默认i == 10在9后面,从而将10也打印出来。即下图为数组在栈中的存放:

                                                      

       接下来,解释为什么,在栈中这样存放数组,以及定义的变量。栈的存放,与先后定义变量有关,先定义的变量a,应该先由栈顶进入栈底,依次进入栈,数组arr[2],其中包括arr[0],以及arr[1],在栈中,栈顶地址小,而栈底地址大,对于地址来说,arr[0]<arr[1],则arr[1]先进栈,arr[0]后进栈。

       代码如下:

#include <stdio.h>
int main ()
{
	int a;
	int b;
	int c;
	int arr[2];

	printf("%u\n%u\n%u\n%u\n%u\n",&a,&b,&c,&arr[0],&arr[1]);
}

         两种变量以及数组进栈的方式如下图:

                                 

        上述代码,编译结果如下:

                                         

        代码输出结果为变量a,b,c,以及数组的的地址。a的地址后三位为964,b的地址后三位为952,c的地址后三位为940,arr[0]的地址后三位为924,arr[1]的地址后三位为928。变量a与变量b,本身都为int型,即4个字节,但964 - 952=12,是因为编译器为防止越界,加了两个位,即8个字节,而数组与数组之间是正常的4个字节,比如arr[1] - arr[0] : 928 - 924=4。同样的道理,为防止数组越界,数组与变量之间也加了两个位,即c - arr[1] : 940 - 928=12。12为本身4个字节以及两个位的字节。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值