C奇怪而有趣的程序输出

Pro*_*mer 6 c memory

我在C中编写了以下代码:

 #include <stdio.h>
 #include <stdlib.h>

 #define LEN 100 

 int main(void) 
 {
    int arr[LEN];
    int i;

    for (i = 0; i < LEN; i++)
       printf("%d ", arr[LEN]);

    getchar();
    return 0;
 }
Run Code Online (Sandbox Code Playgroud)

首先,请注意我故意访问不属于数组的内存(最后一个单元格将在索引中,LEN-1而我正在访问arr[LEN],而不是arr[i].

奇怪的结果是,当我运行程序时,它会打印0到... LEN-1之间的所有数字.例如,当LEN像这里定义为100时,输出为:

0 1 2 ..... 99

请运行该程序.你也遇到过这种情况吗?我认为这是与平台相关的行为.(如果相关,我在Windows 7上运行此代码.)

为什么arr [LEN]的值会发生变化?

Kat*_*ory 7

堆栈是保存局部变量的地方.你的编译器正在使用数组后的内存位置(arr[LEN]基本上)来保存i.因此,您不小心i在每次迭代时打印出来.不同的编译器可能会保留在i其他位置,您不会看到相同的内容.


Fid*_*its 3

要扩展其他人的答案,请考虑以下事项:

代码

#include <stdio.h>
#include <stdlib.h>

#define LEN 100 

int main(void) 
{
    int i;
    int arr[LEN];

    printf("&arr[LEN]: %p\n", &arr[LEN]);
    printf("&i:        %p\n", &i);

    return 0;
}
Run Code Online (Sandbox Code Playgroud)

输出

&arr[LEN]: 0x7fff5cf90a74  
&i: 0x7fff5cf90a74

在我的机器上, ifi是在 之前声明的arri并且arr[LEN]具有相同的地址。

在您的机器上运行以下命令

#include <stdio.h>
#include <stdlib.h>

#define LEN 100 

int main(void) 
{
    int arr[LEN];
    int i;

    printf("&arr[LEN]: %p\n", &arr[LEN]);
    printf("&i:        %p\n", &i);

    return 0;
}
Run Code Online (Sandbox Code Playgroud)

您应该看到与我所看到的非常相似的内容(当然,地址不同)。