我们先看一个程序,说说存在的问题:
char *GetNewMemory(char *p)
{
p = (char *)malloc(100);
}
int main(void)
{
char *p = NULL;
GetNewMemory(p);
strcpy(p, "1234");
printf("p-> : %s\r\n", p);
}
上述程序希望使用GetMemory()函数获取一块新的内存,并通过一个指针参数p获取新内存首地址,事实上main函数中strcpy(p, "1234)中的p仍然是NULL, 并没有达到预期效果。
我们先不做过多解释,先给出正确程序如下:
char *GetNewMemory(char **p)
{
*p = (char *)malloc(100);
}
int main(void)
{
char *p = NULL;
GetNewMemory(&p);
strcpy(p, "1234");
printf("p-> : %s\r\n", p);
}
第二个程序可以达到逾期效果,我们接下来具体分析下原因:
对于没有指针作为参数的一个函数,如int (int a, int b),我们清楚的知道,在函数中修改a和b并不能达到预期效果,因为a和b是形参,是值传递;
接下来我们看下第一个函数char *GetNewMemory(char *p),参数p是一个指针,其实也是一个形参,函数内部会存在一个临时变量_p = p,获取p的指针地址,但是 _p = (char *)malloc(100),本质上函数是申请了一块空间并把首地址赋值给了_p,和p没有任何关系,所以指针获取不到新内存。
然后我们看第二个函数char *GetNewMemory(char **p),函数内部也会有一个临时变量_p = p,注意这个_p是二重指针,(*_p)的内容和(*p)的内容完全一致,所以 *_p = (char *)malloc(100),申请的内存,可以通过二重指针参数p获取。