C++之研究——指针和引用

类别:编程语言 点击:0 评论:0 推荐:

VB中的函数或过程的参数有2种传递方式:一种是值传递;一种是引用传递。分别用关键字ByVal和关键字ByRef指出。如果参数是以引用传递的话,函数或过程内部就可以靠这个引用参数来改变外部变量的值。在C语言中,如果要实现在函数内部改变外部变量的值的话,就应该传递这个变量的指针。如果要通过指针访问变量,必须使用指针运算符“*”。这样在源代码中就会显得比较别扭:

void function(int *pval)
{
 *pval=100;
 //pval=100;先不考虑此处类型转换的错误
 //该代码只能改变堆栈中临时指针变量的地址,而不能改变指针指向对象的值
}

int main()
{
 int x=200;
 function(&x);
 return 0;
}

为了能透明地使用指针来访问变量,C++中引入了“引用”的概念:


void function(int &refval)
{
 refval=100;
}

int main()
{
 int x=200;
 function(x);
 //当然,如下调用也可以。但这样做就失去引入"引用"的原本意义了
 int &refx=x;
 function(refx);
 return 0;
}

这样一来,只要改一下函数声明,就可以在源代码的级别上实现指针访问和一般访问的一致性。可以把“引用”想象成一个不需要“*”操作符就可以访问变量的指针。上面的代码的C语言形式的伪代码:

void function(int *refal)
{
 *refval=100;
}

int main()
{
 int x=200;
 int *refx=&x;
 function(&x);
 function(refx);
 return 0;
}

根据函数的声明,C++编译器在遇到“function (x);”语句时,会自动转换成“function(&x);”形式的二进制代码。

来看“int **pp”和“int *&rp”区别。前者是一个指向指针的指针;后者是一个指针的引用。如果这样看不明白的话,变换一下就清楚了:

typedef int * LPINT;
LPINT *pp;
LPINT &rp;

下面这两个函数的二进制代码是一致的:

void function1(int **p)
{
 **p=100;
 *p=NULL;
}

void function2(int *&ref)
{
 *ref=100;
 ref=NULL;
}

在调用function1或function2时,编译器编译的二进制代码都将传递一个双重指针。

“引用”仅仅是为了给重载操作符提供了方便之门,其本质和指针是没有区别的。

本文地址:http://com.8s8s.com/it/it22797.htm