在使用引用时,我们要知道对参数引用后,引用的权限可以缩小,但是不能放大。
error:
const int c=2;
int& d=c;
//报错:将 "int &" 类型的引用绑定到 "const int" 类型的初始值设定项时,限定符被丢弃
此处的错误可以理解为权限放大,const修饰的c的值是不能改变的,如果int& d=c是可行的,那么对d进行操作——值的修改,将是不合理的。因此对const引用的限制是合理的。
right:
const int c=2;
const int& d=c;
下面来看看何种情况下,c++将生成临时变量,以及如何使用const引用。
函数的返回类型与引用参数正确,但函数的返回参数在函数使用完后销毁。
参数与引用的类型不符合,但可以转化为正确的类型。
case 1:函数的返回类型与引用参数正确,但函数的返回参数在函数使用完后销毁。
#include<iostream>
using namespace std;
int Add(int a, int b)
{
return a + b;
}
int main()
{
const int& c = Add(1, 2);
//如果上行代码改为int& c=Add(1,2);
//将会报错:非常量引用的初始值必须为左值
//因为Add返回的是临时变量,需要const加以限制
return 0;
}
case 2:参数与引用的类型不符合,但可以转化为正确的类型。
error:
int b = 0;
char& a = b;
//报错:无法用 "int" 类型的值初始化 "char &" 类型的引用(非常量限定)
int a=1;
//(double)a就是显式转换,a还是int类型,而(double)a过程中产生了临时变量
在int类型的b到char类型时,产生了临时变量。所以需要const修饰,才能成功定义。
right:
int b = 0;
const char& a = b;