int main()
{
int i = 0;
int arr[10] = { 0 };
for (i = 0; i <= 12; i++)
{
arr[i] = 0;
printf("hehe\n");
}
return 0;
}
这段代码在vs2019的环境下运行为什么会出现死循环,一直打印hehe?
原因如下:
① i和arr是局部变量,局部变量是放在栈区上的,而栈区内存的使用习惯是先使用高地址空间,再使用低地址空间。此时i相较于arr先创建,先分配内存空间。
② 数组随着下标的增长,地址是由低到高变化的,当适当的越界访问,例如arr[12],此时arr[12]的取地址值恰巧就是i的地址值,这时arr[12]赋值为0,导致i又变为0,循环条件又满足,此循环便进入了死循环。
调试如下图所示。
可以看到i和arr[12]的地址值确实一致,当i为11时,arr[12]也为11,依次类推,当i为12时,arr[i] = 0这段代码运行之后,i变为0,导致循环条件又成立。
也就是说,再某些情况下,适当的越界访问数组,可能导致循环进入死循环。
注意:不同的编译环境下,这种类似于巧合出现的情况是不同的!!!
可以看到vs2019以及vs2013中间隔了2个整数。
在gcc编译器下,就是隔1个整数。
在VC 6.0的下,就是隔0个整数。