原理
在不使用全局变量的情况下,用指针变量作函数参数可以将函数外部的地址传递到函数内部,使得在函数内部可以操作函数外部的数据,并且这些数据不会随着函数的结束而被销毁。
错误方法:
#include <stdio.h>
void swap(int a, int b)
{
int temp;
//交换变量内的数据
temp = a;
a = b;
b = temp;
}
int main()
{
int a=5, b=7;
printf("befor swap: a = %d, b=%d\n",a,b);
swap(a,b);
printf("after swap: a = %d, b = %d \n",a,b);
return 0;
}
输出的结果为:
befor swap: a = 5, b=7
after swap: a = 5, b = 7
未能实现变量交换,因为 swap() 函数内部的 a、b 和 main() 函数内部的 a、b 是不同的变量,占用不同的内存,它们除了名字一样,没有其他任何关系,swap() 交换的是它内部 a、b 的值,不会影响它外部(main() 内部) a、b 的值。
正确的代码为:
#include <stdio.h>
void swap(int *a, int *b)//接受地址,类似于在定义指针市的便捷方法:int *a = &x;
{
int temp;
//交换变量内的数据
temp = *a;//把地址a里面的数据给temp,temp = 5
*a = *b;//把地址b里面的数据放到地址a所指的地址的容器内,现在a = 7
*b = temp;//把地址temp里面的数据放到地址b所指的地址的容器,现在b = 5
}
int main()
{
int a=5, b=7;
printf("befor swap: a = %d, b=%d\n",a,b);
swap(&a,&b);//将a,b变量的地址传入子函数,子函数直接操作地址内的数据
printf("after swap: a = %d, b = %d \n",a,b);
return 0;
输出为:
befor swap: a = 5, b=7
after swap: a = 7, b = 5
成功完成变量交换