自定义Swap

网上看到的一篇文章加深了对指针的了解,收藏一下

自定义的swap函数是一个老掉牙的问题,而这个问题对于理解指针和内存中的栈是很有帮助的

一般自定swap函数是这样的:

1.swap函数的功能是实现两个的相互替换

2.在main函数中调用swap函数,以实现main栈中两个数的相互替换

void swap1(int x, int y)

{//当swap1传入的是整形变量时,swap1栈中会开辟了2个整形变量副本,当swap1运行结束时,swap1栈会销毁,所以这两个副本也会销毁。这时,swap1里面的任何操作对man函数栈中的a,b是没有任何作用的,所以是不能交换的

Int temp;

temp = x;

X = y;

Y = temp;

}

void swap2(int *x, int *y)

{//这里边很多人可能就不能理解了!在main栈中,&a指向4的地址,&吧指向5的地址,Swap2函数在swap2栈中定义了两个整形变量指针x,y;一开始x 指向 4的地址,y指向5的地址,函数运行完最后一步时(swap2栈还没销毁前),x指向5的地址,y指向4的地址,这时*x和*y值交换是成功的。但是这种交换并没有改变main栈中&a和&b的指向,&a依然指向的是4的地址,&b依然指向的是5的地址。简单总结一下就是,swap2函数只是交换了x和y的指向的地址,却并没有影响到&a和&b指向的地址

Int *temp;

temp = x;

X = y;

Y = temp;

}

void swap3(int *x, int *y)

{//在main栈中,&a指向4的地址,&吧指向5的地址,Swap2函数在swap2栈中定义了两个整形变量指针x,y;一开始x 指向 4的地址,y指向5的地址。也就是说&a和x指向同一个地址,&b和y指向同一个地址!函数运行完最后一步时(swap2栈还没销毁前),x和y把自己指向的地址的值改变了,这时候的改变就影响到了main栈中&a和&b指向的地址的值,所以交换就成功了

Int temp;

temp = *x;

*x = *y;

*y = temp;

}

Void swap4(int *x, int *y)

{//这个程序运行时是会报段错误的,因为temp没有初始化指针,但是却马山用了它,这是很危险的

Int *temp;

*temp = *x;

*x = *y;

*y = *temp;

}

Int main(void)

{

Int a = 4;

Int b = 5;

swap1(a, b);

Swap2(&a, &b);

Swap3(&a, &b);

return 0;

}

void Swap1(int &a,int &b){
int t;

t=a;
a=b;
b=t;
}

 引用就是某一变量(目标)的一个别名,对引用的操作与对变量直接操作完全一样。

  引用的声明方法:类型标识符 &引用名=目标变量名;

  【例1】:int a; int &ra=a; //定义引用ra,它是变量a的引用,即别名

所以对引用的操作就是对传入变量的操作。


转载:https://blog.csdn.net/duan_jin_hui/article/details/50879338?utm_source=copy

原文地址:https://www.cnblogs.com/henuliulei/p/9783321.html