以指针作为实参时,实参p传递给形参p1的其实是p的拷贝,所以在局部函数中改变形参p1的指向对身处主函数的p是无影响的,但是因为p1是p的拷贝,
所以他们的指向是相同的,所以可以通过p1修改了那块内存的值。如果实参p的指向为空,也就是说p是一个空指针的话,那么它就没有指向某块内存,
形参也就无法操作p所指向的内存了(因为p本就没有指向任何一块内存),即使p1在局部函数中指向了一个malloc的空间,
这其实是改变了p1的指向(从NULL到指向malloc的空间),但是如前所述,p1只是p的拷贝,改变副本的指向对本尊是没有任何影响的,
所以对p没有影响,p还是为空。但是因为p1的生存周期是在局部函数范围内,所以一旦函数执行结束,p1这个变量就会被销毁释放,
但是那块malloc的空间却不会被释放,那就会成为空间碎片。
实参指针为空的一个例子:
#include <stdio.h>
#include <stdlib.h>
void f(int *p1)
{
p1 = (int*)malloc(sizeof(int));
*p1 = 100;
}
int main()
{
int *p = NULL;
f(p);
printf("%d", *p);//程序崩溃,因为p是空指针,试图解引用一个空指针
return 0;
}
实参指针不为空的一个例子:
#include <stdio.h>
#include <stdlib.h>
void f(int *p1)
{
p1 = (int*)malloc(sizeof(int)); //改变了p1的指向,p1指向新分配的那块内存,对主函数中的p无任何影响
*p1 = 100;
}
int main()
{
int a = 10;
int *p = &a;
f(p);
printf("%d", *p); //输出为10
return 0;
}
传一个空指针时可以用二级指针
#include <stdio.h>
#include <stdlib.h>
void f(int **p1)
{
*p1 = (int*)malloc(sizeof(int));
**p1 = 100;
}
int main()
{
int *p = NULL;
f(&p);
printf("%d", *p);//程序崩溃,因为p是空指针,试图解引用一个空指针
return 0;
}