c - C程序打印意外输出
问题描述
我有以下 C 程序:
#include <stdio.h>
void setArr(int, int);
int *arr[10]; // array of 10 int pointers
int main(int argc, char *argv[])
{
int i;
setArr(0, -10);
setArr(1, 100);
setArr(2, 200);
setArr(3, 300);
setArr(4, 400);
for (i = 0; i < 5; i++)
printf("arr[%d] -*-> %d %d\n", i, *arr[i], **(arr + i)); /* should be -10,100, 200,300,400 */
return 0;
}
/* set arr[index], which is a pointer, to point to an integer of value v */
void setArr(int index, int v)
{
int i = v;
arr[index] = &i;
}
它提供以下输出:
arr[0] -*-> 400 400
arr[1] -*-> 400 400
arr[2] -*-> 400 400
arr[3] -*-> 400 400
arr[4] -*-> 400 400
我的理解是,其中的每个元素arr
都是一个指针,它将指向i
在函数内部创建的变量的位置。
我不确定它如何始终始终返回 400
此输出的原因可能是什么以及如何纠正它?
解决方案
函数内部的定义int i = v;
会自动为i
. 当函数执行结束时,内存保留被释放。
一旦内存保留被释放,C 标准不保证任何指向内存的指针的值,你不应该使用这些值。
每次调用setArr
时,都会保留内存然后释放。一个常见的结果是使用相同的内存,因为它被保留、释放、保留、释放等等,并且指针似乎指向相同的位置。然后,您已将 的每个元素设置arr
为指向同一位置。但是,编译器的优化和其他操作可能会产生其他行为。
当然,该位置一次只能保存一个值,因此在调用 后只能在其中看到一个值setArr
。