代码一:
void swap1(int *a,int *b)
{
int *p;
p=a;
a=b;
b=p;
}
int main()
{
int a=5,b=9;
int *p1,*p2;
p1=&a;
p2=&b;
swap1(p1,p2);
printf(“%d %d\n”,a,b);
}
这样是无法成功的,因为地址在里面不管怎样交换和主函数没有一点关系。因为函数在传参的时候得到的是一份复制。而且这份复制在函数结束时就已经消失了,所以主函数并没有任何变化,交换不成功。
代码二:
void swap2(int *a,int *b)
{
int p;
p=*a;
*a=*b;
*b=p;
}
int main()
{
int a=5,b=9;
int *p1,*p2;
p1=&a;
p2=&b;
swap2(p1,p2);
printf(“%d %d\n”,a,b);
}
这个复制是一个指向原本变量的指针,而我们利用这个指针可以间接访问我们需要交换的原本的变量。然后我们将原本变量交换,后面再使用*p1和*p2访问这个两个变量,其实p1和p2的地址并没有变,而是所指向的内容发生了变化。
这里我也明白了函数需要对变量进行修改时,必须传入指针,然后利用指针间接访问变量,再对变量进行修改。这里也必须对函数实参和形参传递理解清楚。
代码三
void swap3(int &a,int &b)
{
int temp=a;
a=b;
b=temp;
}
int main()
{
int a=5,b=9;
int *p1,*p2;
p1=&a;
p2=&b;
swap3(p1,p2);
printf(“%d %d\n”,a,b);
}
该代码可以实现交换功能。
参考: C语言利用指针在函数中交换两个数的思考