标签:48 int 交换 指针 nValue1 nValue2 printf 内存地址 内存
1. 回顾:函数的值传递
因为函数的调用过程中,实参到形参是值传递(值的拷贝),因此,改变形参,是无法影响到实参的:
#include <stdio.h>
void FakeSwap(int nArg1, int nArg2)
{
int nTemp = nArg1;
nArg1 = nArg2;
nArg2 = nTemp;
}
int main(int argc, char* argv[])
{
int nValue1 = 100;
int nValue2 = 200;
printf("交换前:%d, %d\r\n", nValue1, nValue2);
FakeSwap(nValue1, nValue2);
printf("交换后:%d, %d\r\n", nValue1, nValue2);
return 0;
}
运行结果:
以上,形参的改变,无法影响函数调用的实参,因此无法完成nValue1, nValue2的交换。
2. 使用指针交换两个变量的值
#include <stdio.h>
void PointerSwap(int* pArg1, int* pArg2)
{
int nTemp = *pArg1;
*pArg1 = *pArg2; //内存地址所对应的内存区域的数据交换
*pArg2 = nTemp;
}
int main(int argc, char* argv[])
{
int nValue1 = 100;
int nValue2 = 200;
printf("交换前:%d, %d\r\n", nValue1, nValue2);
PointerSwap(&nValue1, &nValue2);
printf("交换后:%d, %d\r\n", nValue1, nValue2);
return 0;
}
运行结果:
使用指针,函数调用过程中依然是值传递,但是,通过指针的解引用操作,根据传入的地址,直接修改了地址处的值,达到了交换的目的
。
实践中,也常通过这种方法,无需返回值,仅使用指针从函数中带出信息,克服C语言中函数只有一个返回值的特点实现读取多个值的作用
。
3. 学习视频地址:通过指针实现函数交换两个变量的值
标签:48,int,交换,指针,nValue1,nValue2,printf,内存地址,内存 来源: https://blog.csdn.net/Dasis/article/details/123087969
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。