首先请读者思考这样一个问题。假设在主函数中已经定义并初始化了两个int型变量a和b,并使用声明为如下形式的void Swap1(int *x,int *y)
的函数欲交换a和b的值,下示代码是否可以完成操作。
void Swap1(int *x,int *y)
{
int *temp;
temp =x;
x = y;
y = temp;
}
不要急着说可以!可以先暂停三十秒慢慢思考。
互换的两种方法:
- 交换地址的方法,使得原本的&a=&b,原本的&b=&a(此处是换地址前的a的地址)。
- 交换值的方法。
乍一看下,确实是利用中间变量交换了形式参数x和y的地址,但是形式参数的值在函数释放后又能否影响实参a,b值的改变呢?
想到这里是否就会理解为什么这样的交换函数并不能使a,b的值如我们所想的那样互换。
1的方法已经证明不能奏效,那么2的思路是否可以呢?写下如下函数。
void Swap2(int *x1,int *y1)
{
int temp;
temp = *x1;
*x1 = *y1;
*y1 = temp;
}
这应该是大家在课本上看见的样子。这在函数中交换了实参a和b内存地址中存放的值。在函数释放后,该值也不会改变。
最后以如下代码为例,证明以上结论成立。
# include<stdio.h>
void Swap1(int *x,int *y)
{
printf("----------Step1----------\n");
printf("befor x is %p\t*x is %d\t&x is %p\n",x,*x,&x);
printf("befor y is %p\t*y is %d\t&y is %p\n",y,*y,&y);
printf("----------\n");
int *temp;
temp =x;
x = y;
y = temp;
printf("after x is %p\t*x is %d\t&x is %p\n",x,*x,&x);
printf("after y is %p\t*y is %d\t&y is %p\n",y,*y,&y);
printf("----------\n");
}
void Swap2(int *x1,int *y1)
{
printf("----------Step2----------\n");
printf("befor x is %p\t*x is %d\t&x is %p\n",x1,*x1,&x1);
printf("befor y is %p\t*y is %d\t&y is %p\n",y1,*y1,&y1);
printf("----------\n");
int temp;
temp = *x1;
*x1 = *y1;
*y1 = temp;
printf("after x is %p\t*x is %d\t&x is %p\n",x1,*x1,&x1);
printf("after y is %p\t*y is %d\t&y is %p\n",y1,*y1,&y1);
printf("----------\n");
}
int main()
{
int a,b;
printf("input a,b=");
scanf("%d %d",&a,&b);
printf("befor_1 a is %d,&a is %p\n",a,&a);
printf("befor_1 b is %d,&b is %p\n",b,&b);
Swap1(&a,&b);
printf("after_1 a is %d,&a is %p\n",a,&a);
printf("after_1 b is %d,&b is %p\n",b,&b);
printf("after-Step1 x=%d,y=%d\n",a,b);
Swap2(&a,&b);
printf("after_2 a is %d,&a is %p\n",a,&a);
printf("after_2 b is %d,&b is %p\n",b,&b);
printf("after-Step2 x=%d,y=%d",a,b);
return 0;
}