前言
疑问1:指针变量作为函数形参,函数内部修改变量中地址,函数退出指针变量中的地址不会改变原因?
回答 : 函数的形参不管是非指针类型(如整型)还是指针类型,在进入函数时,函数内部 生成外部变量的副本,外部变量本身不会改变(在函数内部,接受外部变量的值,这个值对于函数来说是常量,并用形参接受这个常量),实际在函数内部操作的是变量的副本,是对外部变量的一种保护。
疑问2:指针变量作为函数形参,变量地址中存储的值为何能改变?
回答: 函数内部形成的指针变量副本指向的地址不会变,但是地址中的值可以修改成功。
示例
#include <stdio.h>
#include <stdlib.h>
void change(int * elem){
*elem=5;
printf("在函数内部 ,elem指向的地址内的值为:%d\n",*elem);
elem=(int *) malloc(sizeof(int));/*将elem中的地址修改,其实修改的是副本的地址*/
printf("在函数内部 ,elem指向的地址:%p\n\n",elem); /* 在函数内部打印elem执行的地址*/
}
int main()
{
int i=1;
int *elem=&i;
printf("\n");
printf("在函数调用之前,elem指向的地址内的值为:%d\n",*elem);
printf("在函数调用之前,elem指向的地址:%p\n\n",elem);
change(elem);
printf("在函数调用之后,elem指向的地址内的值为:%d\n",*elem);
printf("在函数调用之后,elem指向的地址:%p\n\n",elem); /* 在函数打印elem执行的地址*/
getchar();
return 0 ;
}
运行结果:
比喻
某个学生A(变量A)有一个作业本(内存地址)需要写作业(修改地址中的值),自己不想写,于是找了枪手团队(函数),枪手团队(函数)立马安排了枪手(变量副本),接过学生的作业说,你不用管了,我现在就是你了。枪手成功的完成了作业(修改了地址中的值),由枪手团队将作业本还给学生A。整个过程,作业本没有换(地址没有变),但是作业完成了(地址中的值改变了)。