关于函数的指针传递
来源:互联网 发布:硬座火车座位图片知乎 编辑:程序博客网 时间:2024/05/16 16:14
#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);
}
- 关于函数的指针传递
- 函数指针的传递
- 关于函数的指针与引用参数传递
- [C++]关于指针作为函数参数传递
- [C++]关于指针作为函数参数传递
- 函数指针的传递问题
- 关于指针的浅析---------指针的神奇之处(函数传递参数)
- 关于函数调用的参数传递(数值,指针,二重指针)
- 关于函数调用的参数传递(数值,指针,二重指针)
- 关于指针传递和指针的引用传递
- 值传递-引用传递-指针传递-函数调用时指针参数的传递
- 关于指针的值传递错误
- 关于指针参数的内存传递副本
- 关于指针、引用、值传递的学习
- 关于this指针的传递问题总结
- 关于函数的参数传递
- 关于函数的参数传递
- 关于纯C中如何向函数传递结构体指针的记载
- ASCII,UTF-8,Unicode字符串相互转换(转)
- 打字终于良好了~
- zend studio自动添加文件注释和方法注释
- Apache Commons工具
- 卡片滑动CardSlidePanel问题-分析
- 关于函数的指针传递
- java中的运算符
- 【leetcode】Median of Two Sorted Arrays
- iOS tableViewCell 点击后没有任何变化
- 剑指offer:正则表达式匹配
- LeetCode--54. Spiral Matrix
- hive安装配置
- 1879: 蛤玮买好了礼物 郑轻第八届程序设计大赛
- Java中弱引用、软引用、虚引用及强引用的区别