c++中引用定义的问题
《c++ primer》中这样写的:引用在内部存放的是一个对象的地址,它是该对象的别名。对于不可寻址的值,如文字常量,以及不同类型的对象,编译器为了实现引用,必须生成一个临时对象,引用实际上是指向该对象,但用户不能访问它。
比如:
1
double dval = 1024;
2
const int &ri = dval;
编译器将其转换成:
1
int temp = dval;
2
const int &ri = temp;
这是符合不同类型的对象的。
c++中 不允许非const引用指向需要临时对象的对象或值。(因为如果修改引用的话,改变的是临时对象的值)
比如:
1
double dval = 1024;
2
int &ri = dval; //error
书中有这样的一个例子,要求将一个引用初始化为一个const对象的地址。
1
const int ival = 1024;
2
3
//错误:要求一个const引用
4
int ×&pi_ref = &ival;
之所以需要一个const引用是因为 不允许非const引用指向需要临时对象的对象或值。
1
const int ival = 1024;
2
//仍然错误
3
const int ×&pi_ref = &ival;
仍然错误是因为等号两边是不同的类型,必须使用const。
1
const int ival = 1024;
2
3
//ok
4
const int *const &pi_ref = &ival;
如果想不使用第二个const,可以这样:
1
const int ival = 1024;
2
const int *pi = &ival;
3
4
const int *&pi_ref = pi;
但是第一个const是必须的。
在初始化引用参数的时候也有这样的问题。
1
int obj;
2
void frd(double &);
3
int main()
4
{
5
frd(obj); //错误:参数必须是const double &
6
return 0;
7
}
因为由int到double的转换会生成一个临时对象。如果允许这种转换的话,在frd中修改obj的值,改变的将是临时对象的值,这与前面的问题又相同了。
另一个例子:
1
class B;
2
void takeB(B &);
3
B giveB();
4
5
int main()
6
{
7
takeB( giveB() ); // 错误,参数必须是const B &
8
return 0;
9
}
1
void print(int);
2
void print(int &);
3
4
int main()
5
{
6
print(86); // 调用print(int)
7
return 0;
8
}
摘自 Orion的博客
补充:软件开发 , C++ ,