刚学指针的人多会遇到这样的情况,就是你给一个函数传递一个指针变量,在这个函数中为这个指针申请空间,赋值,可是等函数结束后这个指针还是一个空指针,对其的操作编译器会报段错误或干脆给你一个莫名其妙的值,这是一个随机数。
#include <stdio.h> #include <stdlib.h> int my_fun(int *p) { p = (int *)malloc(sizeof(int)); *p = 101; return 0; } int main(int argc, char **argv) { int *p; my_fun(p); printf(“%d\n”,*p); return 0; }
这个函数最终打印的结果是一个随机数。这是为什么呢?
这里先说一点函数调用时候的事情:
函数在被调用的时候,系统动态的为其在堆栈区分配一段空间,这段空间的作用是:
1、 在进入函数前保存环境变量和返回地址。
2、 在进入函数时保存实参的拷贝。
3、 在函数体内,保存局部变量。
在这里可以看出一点什么,就是,在调用函数的时候,系统为函数动态的分配了一段空间,且为实参做了拷贝,在函数中的‘p’只是主函数中‘p’的一个拷贝,我们申请空间、赋值等操作都是对这个拷贝进行的。当函数体结束的时候,这个拷贝的生命也就结束了,系统收回了为函数分配的空间,包括这个拷贝。这就是为什么我们申请空间、赋值等操作看起来都没有效果。
解决这个问题有多种方法,这里就介绍一点:
如下就可以解决这个问题:
#include <stdio.h> #include <stdlib.h> int *my_fun(int *p) { p = (int *)malloc(sizeof(int)); *p = 101; return p; } int main(int argc, char **argv) { int *p; p = my_fun(p); printf(“%d\n”,*p); return 0; }
在这里通过返回值,是函数中的‘p’的生命期延长了,最终就达到了我们预期的效果。下面这个也可以完成。
#include <stdio.h> #include <stdlib.h> int my_fun(int *p) { *p = 101; return 0; } int main(int argc, char **argv) { int *p; p = (int *)malloc(sizeof(int)); my_fun(p); printf(“%d\n”,*p); return 0; }