如果函数的参数是一个指针,不要指望用该指针去申请动态内存。下面代码中
test 函数的语句 memory_get(str, 100)并没有使 str 获得期望的内存,str 依旧是 NULL,为什么?
void memory_get(char *str, int size)
{
str = (char *)malloc(sizeof(char) * size);
}
void test(void)
{
char *str = NULL;
memory_get(str, 100); // str 仍然为 NULL
strcpy(str, "hello"); // 运行错误
}
毛病出在函数 memory_get 中。编译器总是要为函数的每个参数制作临时副本,指针参数str 的副本是 _str,编译器使 _str = str。如果函数体内的程序修改了_str 的内容,就导致参数 str 的内容作相应的修改。这就是指针可以用作输出参数的原因。
也就是C语言的传值调用,什么是传值调用呢?顾名思义,传值调用就是直接将实参的值传递给形参。这样形参和实参的值是一样的,但是函数的形参和实参分别占有不同的内存块,实参是一个独立的个体,形参也是一个独立的个体,只是形参的值与实参相同。但实际两者之间并没有建立起真正的联系,对形参的修改不会影响实参。
在本例中,_str 申请了新的内存,只是把_str 所指的内存地址改变了,但是 str 丝毫未变。所以函数 memory_get并不能输出任何东西。事实上,每执行一次memory_get 就会泄露一块内存,因为没有用free 释放内存。
如果非得要用指针参数去申请内存,那么应该改用“指向指针的指针”,也就