分析函数传参及返回值
来源:互联网 发布:linux安装软件常用方式 编辑:程序博客网 时间:2024/05/18 18:47
刚学指针的人多会遇到这样的情况,就是你给一个函数传递一个指针变量,在这个函数中为这个指针申请空间,赋值,可是等函数结束后这个指针还是一个空指针,对其的操作编译器会报段错误或干脆给你一个莫名其妙的值,这是一个随机数。
#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;}
0 0
- 分析函数传参及返回值
- 浅析函数传参及返回值
- 关于函数传参及返回值
- 浅析函数传参及返回值
- socket函数返回值分析
- 函数参数及返回值
- OPEN()函数及返回值
- SOCKET 常用函数的返回值分析
- 对于中断函数返回值的分析
- main()函数返回值的分析
- SOCKET 常用函数的返回值分析
- SOCKET 常用函数的返回值分析
- system函数返回值测试分析
- 对于中断函数返回值的分析
- SOCKET 常用函数的返回值分析
- 临时对象作为函数返回值返回的分析
- 函数返回指针分析
- open函数参数及返回值
- 看看新的集合在Facebook上拥有
- 看在玛卡根,一个在Extagen的主要成份的
- fastjson混淆后default constructor not found.
- 看看微软的CRM软件
- 目前存储数据和文件
- 分析函数传参及返回值
- 理由使用CRM软件在您的业务
- 理由使用网络传真
- 1291 数据结构上机测试4.1:二叉树的遍历与应用1
- 理解什么包的Windows 8消费者预览版
- JSP内置对象和分页查询
- 理解现代科学计算器的使用与应用
- 玛雅预言2012的误区
- 玛雅日历和2012年12月,whats的新政