#include<stdio.h>
void swap(int a,int b)
{
a =a^b;
b=a^b;
a=a^b;
}
void swap2(int &a,int &b)
{
a=a^b;
b=a^b;
a=a^b;
}
int main()
{
//补充函数调用
return 0;
}
编译 gcc -o swap swap.c // g++ -o swap swap2.c (包含引用&只能用g++编译,用gcc编译会提示出错)
我们可以用objdump -x -s swap 查看反汇编,得到汇编代码。我们查看到当用&引用时,在生成临时变量时,把变量和地址都会保存,然后把
地址传给了函数,这样在交换数据之后就会改变原数据的值。
而没有加引用的函数,则仅是在临时空间内生成变量,对原变量没有改变,当函数退出时,临时变量都会被删除,无法产生作用。
对汇编的学习:
每一个函数的开头都需要操作
push ebp
mov ebp esp
这个操作的意思是,保持上一个函数的ebp,然后将新的esp的值赋值给ebp,此时ebp的值为新的函数段的起始地址。
在i386系统中默认对栈操作的寄存器指针有ebp和esp,而esp表示栈的顶端指针,则ebp指向栈的低端地址。