我在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]的值会发生变化?
堆栈是保存局部变量的地方.你的编译器正在使用数组后的内存位置(arr[LEN]基本上)来保存i.因此,您不小心i在每次迭代时打印出来.不同的编译器可能会保留在i其他位置,您不会看到相同的内容.
要扩展其他人的答案,请考虑以下事项:
代码
#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是在 之前声明的arr,i并且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)
您应该看到与我所看到的非常相似的内容(当然,地址不同)。