如果是對一個常量進行引用,則編譯器首先建立一個臨時變量,然後將該常量的值置入臨時變量中,對該引用的操作就是對該臨時變量的操作。對C++常量引用可以用其它任何引用來初始化;但不能改變。
關於引用的初始化有兩點值得注意:
(1)當初始化值是一個左值(可以取得地址)時,沒有任何問題;
(2)當初始化值不是一個左值時,則只能對一個const T&(常量引用)賦值。而且這個賦值是有一個過程的:
首先將值隱式轉換到類型T,然後將這個轉換結果存放在一個臨時對象裡,最後用這個臨時對象來初始化這個引用變量。
例子:
& dr = ; & cdr = ;
第二句實際的過程如下:
temp = ( & cdr = temp;
作函數參數時:
#include f(C & c) { cout << << f(C & c) { cout << <<
結果:
C const &
更直接的,用基本類型:
#include <iostream> display( &) {cout<<<< i= anotheri=+<>(
通過C++常量引用從函數返回一個局部對象:
一般從一個函數返回一個局部對象的引用是不對的:
T & my_op (
特殊情況:返回一個常引用
T & my_op ( T & my_t_obj = my_op ();
在這個情況下,局部變量 t 不會被直接析構,而是會保留到 my_t_obj 的生命周期結束為止。
總之,C++常量引用語法上可以引用一個臨時變量。這種方法在使用引用作函數參數和返回局部變量時有意義。我目前看來常量引用主要用在作函數參數或保證不修改原變量的時候。