const引用与非const引用

const引用只读不可修改,与绑定对象是否为const无关。对象

非const引用可读可改,只可与非const对象对象绑定blog

const intival = 1024;

//int &ref2 = ival; //error:nonconst reference to a const object

const int&refval = ival; //ok:both reference and objectare const

  

非const引用只能绑定到与该引用同类型的对象,const引用则能够绑定到不一样但相关的类型的对象或绑定到左值,编译器

const引用能够初始化为不一样类型的对象或者初始化为右值,如字面值常量编译

int i = 42;

//legal for constreference only

const int&r = 42;

const int&r2 = r + i;

double dval = 3.14;

const int&ri = dval;

  

上面,一样的初始化对于非const引用是不合法的,将致使编译误。class

引用在内部存放的是一个对象的地址,它是该对象的别名。对于不可寻址的值,如文字常量,以及不一样类型的对象,编译器为了实现引用,必须生成一个临时对象,引用实际上指向该对象,但用户不能访问它。dva

例如:变量

double dval = 23;

const int &ri = dval;

 

编译器将其转换为:object

 

int tmp = dval; //double -> int

const int &ri = tmp;

const int t = 9;

const int &k = t;

cout << &t << endl;

cout << &k << endl;

 

{

   intt = 9;

   int&k = t;

   cout << &t <<endl;

   cout << &k <<endl;

}

  

若是是对一个常量进行引用,则编译器 首先创建一个临时变量,而后将该常量的值置入临时变量中,对该引用的操做就是对该临时变量的操做。引用

const引用表示,试图经过此引用去(间接)改变其引用的对象的值时,编译器会报错!这并意味着,此引用所引用的对象也所以变成const类型了。咱们仍然能够改变其指向对象的值,只是不经过引用.。error

int main()

{

       int ival= 1024;

       const int &ir = ival;

 

       ival++;

       //ir++;

 

       cout << ival << " " << ir << endl;

 

    system("pause");

       return 0;

}
相关文章
相关标签/搜索