直接看代码:
//交换两个数
//函数
void Swap(int* px, int* py)
{
int c = 0;
c = *px;
*px = *py;
*py = c;
}
int main()
{
//定义两个数
int a = 0;
int b = 0;
//输入:
scanf("%d %d", &a, &b);
//打印交换前:
printf("交换之前a = %d,b = %d",a,b);
//交换函数:
Swap(&a,&b);
//打印交换后:
printf("交换之后a = %d,b = %d",a,b);
return 0;
}
主函数里的Swap函数之所以传的是a和b的地址而不是a和b,是因为传a和b时只是把他们的值传递给了定义的Swap函数的形参,用于计算,这里我要起的作用是交换,简单看一下就明白,但问题出在哪里呢?
因为,形参本身也有自己的内存地址,我们把实参的值传递过去,存放在了形参的空间里,于是乎,对形参进行了a和b值的交换,却影响不了实参,因为他们的地址是不同的,可以复制代码自己去调试,我忘了截图。 这样的话,运行出来的结果依然是a和b的值没有交换。
所以采用了传地址的方式,然后定义的Swap函数的形参用指针来接受地址,通过直接对指针的赋值来在地址上进行修改,最后影响到实参。
注意,加法乘法这种函数不需要传地址,因为他们只是需要值,把值传过去,返回结果就可以,但交换需要地址。