#include <stdio.h>
#include <stdlib.h>
void F(int *pi)
{
pi = (int *)malloc(sizeof(int));
}
main()
{
int *pi = NULL;
F(pi);
printf("%d/n", pi == NULL);
}
如果你指望函数F能帮你改变pi的值,那你就错了,运行上面这段代码,你会发现输出是1。刚开始我也很诧异,我不是传了指针进去吗,为什么没能保留改变的结果呢?
别着急,再看看下面一段代码:
#include <stdio.h>
#include <stdlib.h>
void F(int *pi)
{
*pi = 5;
}
main()
{
int i = 0;
F(&i);
printf("%d/n", i);
}
这次运行代码,i的值被函数F改变了。对比一下两段代码,你会发现:第二段代码中传给函数F的实参是一个整型变量地址的拷贝,函数F拿到了这个地址,改变的是这个地址指向的变量。这样当然可以成功,地址和其拷贝的值是一样的,所以按照这两个地址找到的变量自然也是一样的。第一段代码则完全不同,虽然传给函数F的实参也是一个整型变量地址的拷贝,但函数F试图通过改变这个拷贝来改变原来的地址值,这当然行不通,因为指针和它的拷贝是两个变量。指针也是变量,它在函数调用过程中也是传值调用的。其实第一段代码和下面这段代码效果是类似的:
#include <stdio.h>
#include <stdlib.h>
void F(int i)
{
i = 5;
}
main()
{
int i = 0;
F(i);
printf("%d/n", i);
}
这段代码大家一看就知道函数F不会改变i的值,因为主函数传给F的只是变量i的一份拷贝,改变拷贝的值并不会影响原变量的值。其实这段代码和第一段有什么区别呢,不过一个是整型变量,一个是指针变量,它们都是传值调用的。
那么如何修改第一段代码好让它符合我们的要求呢?其实只需让函数F简单地返回地址:
#include <stdio.h>
#include <stdlib.h>
int *F()
{
return (int *)malloc(sizeof(int));
}
main()
{
int *pi = NULL;
pi = F();
printf("%d/n", pi == NULL);
}