答案显示是不会,这个比较难了。我大一一直没弄懂。
之前想的问题是,为什么在函数中malloc很多内存,然后用指针指向他们,最后真的可以改变整个单链表,当然前提是带头结点且加了引用类型的。
这个地方比较玄学,可能是C语言最难的部分了。
#include <bits/stdc++.h>
using namespace std;
void f(int *a[],int n)
{
int i=5;
int *p=&i;
printf("now we are in the function,at this time &i equals %d\n",&i);
a[n]=p;
}
int main()
{
int *a[100]={NULL};
if(a[1]==NULL)
printf("before the function call,a[1] is NULL\n");
else
printf("before the function call,a[1] is %d\n",a[1]);
f(a,1);
if(a[1]==NULL)
printf("after the function call,a[1] is NULL\n");
else
printf("after the function call,a[1] is %d\n",a[1]);//这说明虽然函数调用结束了,i没了,但是此时a[i]却完好无损的等于当初函数内部&i的值,真的是太神奇了
return 0;
}
细心的读者可以发现,函数结束调用时,我的i其实已经被释放掉了,但是我的a[1]还是没有改变,也就是说a[1]的值存的是地址,地址是永远在那不会变的,因此就算i被释放掉,指针数组还是不会撤销变回原来的值。