C++对于参数的传递详解

来源:互联网 发布:redis消息队列 php 编辑:程序博客网 时间:2024/06/14 03:24

/*************************************/

主要有  1、值传递

        2、指针传递

        3、引用传递

/***************************************/

#include "stdafx.h"

#include "thisPoint.h"
#include "Distance_two_point.h"
using namespace std;


// 值传递
void swap(int p, int q)
{
  cout << p << ":" <<q << endl;
  int temp;
  temp = p;
  p = q;
  q = temp;
  cout << p<< ":" <<q<< endl;
}


//指针传递
void swap2(int *p, int *q)  //初学者要牢记这是个指针定义,不要其和*p 混淆
{
int temp;      //p0x008af98c {1}int *  -->>a的地址
temp = *p;     //   q0x008af980 {2}int *  -->>b的地址
*p = *q;        //p0x008af98c {2}int *  -->>a的地址
*q = temp;     //   q0x008af980 {1}int *  -->>b的地址
}


//引用,所谓引用就是同名代换,int &p =a;也就是说对a操作就是对p操作;
void swap4(int &p, int &q)
{
  int temp;
  temp = p;
  p = q;
  q = temp;
}


int _tmain(int argc, _TCHAR* argv[])
{

int a = 1, b = 2;
cout << a << ":" << b << endl;
swap4(a,b);
cout << a << ":" << b << endl;

return 0;

}

下面是从编译器的角度来看待问题:

1.值传递

swap1函数实现的值传递,值传递传递的是实际参数的一个副本,如果对这句话不理解,那一步步调试看下内存分配情况。

执行到48行时,a和b的情况如下

接着进入swap1函数体内,如下所示

可以看到的是,p和q的地址和a与b的地址不一样,只是把a和b的值拷贝过去了,在swap1中对p和q操作只是对临时分配的栈中内容进行操作,函数执行完后形参就消失了,对原来的a和b不产生任何影响。所以swap1不能完成交换a和b值的功能

2.指针传递

swap2和swap3都是指针传递,swap2函数体内交换了p和q指向地址的值,swap3函数体内交换了p和q指向的地址。

先说swap2,进入swap2函数体内,如下所示

可以看到,形参指针p和q指向的是a和b的地址,而不是像值传递那样将实参的值拷贝到另外分配的地址中,运行到函数尾时,如下图

可以看到、指针p和q指向的地址没变,但地址中的值变了,也即a和b地址中的变了,就是a和b的值成功交换,继续调试可以看到正确的结果,如下图

再来看swap3,swap3运行到函数尾时的情况如下

可以看到p和q交换了地址,但最后函数执行完后的结果又如下所示

a和b的值并未交换,这是为什么呢?

swap3中,形参p和q会保存在栈中,p指向a的地址,q指向b的地址,使用temp指针完成了p和q的地址交换,即p指向b的地址,q指向了a的地址,但a和b地址中的值并未发生变化,这与swap2不同,swap2中是p指向的地址中的值(就是a)与q指向的地址中的值(b)交换,所以swap2执行完后a和b的值是交换了的。

3.引用传递

引用传递时,对形参的操作等同于对实参的操作,即传递的不会是实参的副本,而就是实参,进入swap4函数体内如下所示


原创粉丝点击