指针引用就是一个指针的引用,看下面例1:
int a = 10;
int b = 20;
void swap(int& lhs, int& rhs)
{
int tmp = lhs;
lhs = rhs;
rhs = tmp;
}
swap(a, b);
上面的程序可以成功交换两个int值,但是如果形参传的是int而非其引用的话则不会交换2个int值,因为形参非引用的情况下,编译器会复制a,b然后把a,b的拷贝传到swap函数中,交换的只是a,b的拷贝而已,所以失败。但是传引用则可以成功。
例2:
/* 查找机车
* @name: 机车名字
* @crg: 被查找到的机车
* @return: 未找到机车返回false;否则返回true
*/
bool find(LPCTSTR name, Carriage* &crg);
bool CRG_Repository::find(LPCTSTR name, Carriage *&crg)
{
for (size_t i=0;i<crgs_.size();i++)
{
if (name==crgs_[i]->name())
{
crg=crgs_[i];
return true;
}
}
return true;
}
上面程序根据name查找机车,其中机车存放在一个容器中:std::deque<Carriage *> crgs_
并返回找到的这个机车的指针。
如果find函数的第二个参数不传指针的引用而传指针的话,可能如下所示:
Carriage* found;
CRG_Repository crep;
crep.find("123", found);
这样的调用不会改变found这个指针的值,find函数仅仅改变了found的拷贝而已,所以失败。
当传指针引用的时候则会成功,因为:传引用编译器不会拷贝一个found传到find函数中去,而是直接传递found,在find函数内部的修改就是found本身,而不是它的拷贝;修改完后,found的值变了,当然可以成功。
当然这个find函数也可以这样
Carriage* find(LPCTSTR name);
所以传指针引用的目的是要修改这个指针,调用函数之后修改这个指针的值,获得这个修改后的值以备他用。
总结一下:传引用的目的一般是为了修改这个传递的是引用的参数,然后返回这个值(以后程序中会用到);或者是不让编译器对参数进行拷贝,提高效率。