C++引用基本概念详解

C++编程语言中有很多应用方法和C语言有相同之处。那么作为C语言的升级版本,它又有哪些不同之处呢?首先让我们从C++引用的基本概念来解读这一问题,希望能够帮助大家轻松掌握这一语言的特点。#t#

一、C++引用的概念

引用引入了对象的一个同义词。定义引用的表示方法与定义指针相似,只是用&代替了*。

例如: Point pt1(10,10);

Point &pt2=pt1; 定义了pt2为pt1的引用。通过这样的定义,pt1和pt2表示同一对象。

需要特别强调的是C++引用并不产生对象的副本,仅仅是对象的同义词。因此,当下面的语句执行后:

pt1.offset(2,2);

pt1和pt2都具有(12,12)的值。

C++引用必须在定义时马上被初始化,因为它必须是某个东西的同义词。你不能先定义一个引用后才初始化它。例如下面语句是非法的:

 

 
 
 
  1. Point &pt3;  
  2. pt3=pt1; 

 

那么既然引用只是某个东西的同义词,它有什么用途呢?

下面讨论C++引用的两个主要用途:作为函数参数以及从函数中返回左值。

二、引用参数

传递可变参数

传统的c中,函数在调用时参数是通过值来传递的,这就是说函数的参数不具备返回值的能力。

所以在传统的c中,如果需要函数的参数具有返回值的能力,往往是通过指针来实现的。比如,实现

两整数变量值交换的c程序如下:

 

 
 
 
  1. void swapint(int *a,int *b)  
  2. {  
  3. int temp;  
  4. temp=*a;  
  5. *a=*b;  
  6. *b=temp;  

 

使用C++引用机制后,以上程序的C++版本为:

 

 
 
 
  1. void swapint(int &a,int &b)  
  2. {  
  3. int temp;  
  4. temp=a;  
  5. a=b;  
  6. b=temp;  

 

调用该函数的C++方法为:swapint(x,y); C++自动把x,y的地址作为参数传递给swapint函数。

THE END