我已经声明了一个长度为N的数组(假设)。现在,我使用循环为这个数组的元素赋值(循环变量用作数组的索引)。代码如下:
int main()
{
int arr[4], j;
for(j=0; j<10; j++)
{
printf("%d\n", j);
arr[j] = 0;
sleep(1);
printf("%d\n\n", j);
}
return 0;
}
我预计输出为0 1 2 .. 9.但是实际发生的是当赋值arr [N + 2] = 0时,j被重置为0(在这种情况下,arr [6] = 0)在循环中执行。 这里到底发生了什么?我错过了什么吗?
答案 0 :(得分:8)
你的数组有4个元素,你的索引超出范围,所以你只是在踩踏内存。
考虑到这里的代码,我希望arr[4]
重置数组,但既然你提到它的长度N
而N+2
是导致它的原因,那么可能会有一些在你的堆栈中填充。在任何情况下,当您声明数组和j
时,它们都会被放入堆栈中。在您的情况下,j
处于这样的位置:当您的索引超出范围时,您正在访问j
所在的内存。
答案 1 :(得分:3)
代码的行为未定义,因为它有一个错误。 arr的大小为4,但您使用j
索引超过此大小答案 2 :(得分:2)
你的阵列溢出了。你用4个元素定义它:
int arr[4]
但是你要分配10个元素。
j
显然位于数组之后,因此当您指定arr[6] = 0
时,您正在清除j
。